

# NEC

# µPD78083 SUBSERIES

## **8-BIT SINGLE-CHIP MICROCONTROLLER**

μPD78081 μPD78081(A) μPD78082 μPD78082(A) μPD78P083 μPD78P083(A) μPD78P081(A2)

> Document No. U12176EJ2V0UM00 (2nd edition) (O. D. No. IEU-886) Date Published May 1997 N Printed in Japan

#### **1** PRECAUTION AGAINST ESD FOR SEMICONDUCTORS

#### Note:

Strong electric field, when exposed to a MOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop generation of static electricity as much as possible, and quickly dissipate it once, when it has occurred. Environmental control must be adequate. When it is dry, humidifier should be used. It is recommended to avoid using insulators that easily build static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work bench and floor should be grounded. The operator should be grounded using wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions need to be taken for PW boards with semiconductor devices on it.

#### ② HANDLING OF UNUSED INPUT PINS FOR CMOS

#### Note:

No connection for CMOS device inputs can be cause of malfunction. If no connection is provided to the input pins, it is possible that an internal input level may be generated due to noise, etc., hence causing malfunction. CMOS devices behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using a pull-up or pull-down circuitry. Each unused pin should be connected to VDD or GND with a resistor, if it is considered to have a possibility of being an output pin. All handling related to the unused pins must be judged device by device and related specifications governing the devices.

#### **③** STATUS BEFORE INITIALIZATION OF MOS DEVICES

#### Note:

Power-on does not necessarily define initial status of MOS device. Production process of MOS does not define the initial operation status of the device. Immediately after the power source is turned ON, the devices with reset function have not yet been initialized. Hence, power-on does not guarantee out-pin levels, I/O settings or contents of registers. Device is not initialized until the reset signal is received. Reset operation must be executed immediately after power-on for devices having reset function.

FIP, IEBus, and QTOP are trademarks of NEC Corporation.

MS-DOS and Windows are either registered trademarks or trademarks of Microsoft Corporation in the United States and/or other countries.

IBM DOS, PC/AT and PC DOS are trademarks of International Business Machines Corporation.

HP9000 Series 300, HP9000 Series 700, and HP-UX are trademarks of Hewlett-Packard Company.

SPARCstation is a trademark of SPARC International, Inc.

Sun OS is a trademark of Sun Microsystems, Inc.

Ethernet is a trademark of XEROX Corporation.

NEWS and NEWS-OS are trademarks of SONY Corporation.

OSF/Motif is a trademark of Open Software Foundation, Inc.

TRON is an abbreviation of The Realtime Operating system Nucleus.

ITRON is an abbreviation of Industrial TRON.

The export of these products from Japan is regulated by the Japanese government. The export of some or all of these products may be prohibited without governmental license. To export or re-export some or all of these products from a country other than Japan may also be prohibited without a license from that country. Please call an NEC sales representative.

 The application circuits and their parameters are for reference only and are not intended for use in actual design-ins.

#### The information in this document is subject to change without notice.

No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Corporation. NEC Corporation assumes no responsibility for any errors which may appear in this document.

NEC Corporation does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from use of a device described herein or any other liability arising from use of such device. No license, either express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Corporation or others.

While NEC Corporation has been making continuous effort to enhance the reliability of its semiconductor devices, the possibility of defects cannot be eliminated entirely. To minimize risks of damage or injury to persons or property arising from a defect in an NEC semiconductor device, customers must incorporate sufficient safety measures in its design, such as redundancy, fire-containment, and anti-failure features.

NEC devices are classified into the following three quality grades:

"Standard", "Special", and "Specific". The Specific quality grade applies only to devices developed based on a customer designated "quality assurance program" for a specific application. The recommended applications of a device depend on its quality grade, as indicated below. Customers must check the quality grade of each device before using it in a particular application.

- Standard: Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots
- Special: Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support)
- Specific: Aircrafts, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems or medical equipment for life support, etc.

The quality grade of NEC devices is "Standard" unless otherwise specified in NEC's Data Sheets or Data Books. If customers intend to use NEC devices for applications other than those specified for Standard quality grade, they should contact an NEC sales representative in advance.

Anti-radioactive design is not implemented in this product.

### **Regional Information**

Some information contained in this document may vary from country to country. Before using any NEC product in your application, please contact the NEC office in your country to obtain a list of authorized representatives and distributors. They will verify:

- Device availability
- Ordering information
- Product release schedule
- Availability of related technical literature
- Development environment specifications (for example, specifications for third-party tools and components, host computers, power plugs, AC supply voltages, and so forth)
- Network requirements

In addition, trademarks, registered trademarks, export restrictions, and other legal issues may also vary from country to country.

NEC Electronics Inc. (U.S.) Santa Clara, California Tel: 800-366-9782 Fax: 800-729-9288

NEC Electronics (Germany) GmbH Duesseldorf, Germany Tel: 0211-65 03 02 Fax: 0211-65 03 490

**NEC Electronics (UK) Ltd.** Milton Keynes, UK Tel: 01908-691-133 Fax: 01908-670-290

**NEC Electronics Italiana s.r.1.** Milano, Italy Tel: 02-66 75 41 Fax: 02-66 75 42 99 NEC Electronics (Germany) GmbH Benelux Office Eindhoven, The Netherlands Tel: 040-2445845 Fax: 040-2444580

NEC Electronics (France) S.A. Velizy-Villacoublay, France Tel: 01-30-67 58 00 Fax: 01-30-67 58 99

NEC Electronics (France) S.A. Spain Office Madrid, Spain Tel: 01-504-2787 Fax: 01-504-2860

NEC Electronics (Germany) GmbH Scandinavia Office Taeby, Sweden Tel: 08-63 80 820 Fax: 08-63 80 388 NEC Electronics Hong Kong Ltd. Hong Kong Tel: 2886-9318 Fax: 2886-9022/9044

NEC Electronics Hong Kong Ltd. Seoul Branch Seoul, Korea Tel: 02-528-0303 Fax: 02-528-4411

NEC Electronics Singapore Pte. Ltd. United Square, Singapore 1130 Tel: 253-8311 Fax: 250-3583

NEC Electronics Taiwan Ltd. Taipei, Taiwan Tel: 02-719-2377 Fax: 02-719-5951

**NEC do Brasil S.A.** Sao Paulo-SP, Brasil Tel: 011-889-1680 Fax: 011-889-1689

### Major Revision in This Edition

| Page        | Description                                                                                                                                                                                                                             |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Throughout  | The following products have been already developed<br>μPD78081CU-xxx, 78081GB-xxx-3B4, 78082CU-xxx, 78082GB-xxx-3B4, 78P083CU, 78P083DU, 78P083GB-3B4                                                                                   |
|             | The following products have been added<br>μPD78081GB-xxx-3BS-MTX, 78082GB-xxx-3BS-MTX, 78P083GB-3BS-MTX, 78081GB(A)-xxx-3B4,<br>78082GB(A)-xxx-3B4, 78P083CU(A), 78P083GB(A)-3B4, 78P083GB(A)-3BS-MTX, 78081GB(A2)-xxx-3B4              |
|             | Changes supply voltage to $V_{DD} = 1.8$ to 5.5V.                                                                                                                                                                                       |
| p. 9        | 1.6 78K/0 Series Development has been changed.                                                                                                                                                                                          |
| p. 13       | 1.9 Differences between the $\mu$ PD78081, 78082, and 78P083, the $\mu$ PD78081(A), 78082(A), and 78P083(A), and the $\mu$ PD78081(A2) has been added.                                                                                  |
| p. 19       | Cautions regarding the use of functions in common with 2.2.5 (2) (d) ASCK has been added.                                                                                                                                               |
| p. 72       | Cautions concerning the Write to OSMS Command has been added to <b>5.3 (2) Oscillation mode select</b> register (OSMS).                                                                                                                 |
| p. 73       | Cautions concerning external clock input in 5.4.1 Main system clock oscillator has been changed.                                                                                                                                        |
| p. 108      | Figure 7-3. Watchdog Timer Mode Register Format, notes and cautions have been added.                                                                                                                                                    |
| p. 110      | Description of 7.4.2 Interval timer operation has been changed.                                                                                                                                                                         |
| p. 113      | Cautions with regard to rewriting TCL0 to other than same data has been added to 8.3 (1) Timer clock select register 0 (TCL0).                                                                                                          |
| p. 120      | The HSC bit has been added to the A/D Converter Mode<br>Register in Figure10-1. A/D Converter Block Diagram.                                                                                                                            |
| p. 122, 193 | 10.3 (1) A/D converter mode register (ADM), 13.1.1 Standby function, and Cautions have been added.                                                                                                                                      |
| p. 137      | Figure 11-1. Serial Interface Channel 2 Block Diagram has been corrected.                                                                                                                                                               |
| p. 146, 155 | <ul> <li>11.3 (4) (a), 11.4.2 (1) (d) (i) Generation of baud rate transmit/receive clock by means of main system clock have been added.</li> <li>76800 bps has been added to baud rate generated from the main system clock.</li> </ul> |
| p. 161      | Figure 11-10. Receive Error Timing has been corrected.                                                                                                                                                                                  |
| p. 165      | 11.4.3 (1) (c) Baud rate generator control register (BRGC) has been added.                                                                                                                                                              |
| p. 168      | 11.4.3 (3) MSB/LSB switching as start bit has been added.                                                                                                                                                                               |
| p. 206      | 15.1 Memory Size Switching Register has been changed from W to R/W.                                                                                                                                                                     |
| p. 205      | Items and cautions have been added to Table 15-1. Differences between the $\mu$ PD78P083 and Mask ROM Versions.                                                                                                                         |
| p. 214      | A description of the QTOP microcontroller has been added to <b>15.5 Screening of One-Time PROM</b><br>Versions.                                                                                                                         |
| p. 232      | Figure A-1. Development Tool Configuration has been changed.                                                                                                                                                                            |
| p. 231      | APPENDIX A DEVELOPMENT TOOLS<br>The following Development Tools have been added:<br>IE-78000-R-A, IE-70000-98-IF-B, IE-70000-98N-IF, IE-70000-PC-IF-B, IE-78000-R-SV3, SM78K0, ID78K0                                                   |
| p. 239      | A.4 OS for IBM PC has been added.                                                                                                                                                                                                       |
| p. 240      | Table A-2. System-Up Method from Other In-Circuit Emulator to IE-78000-R-A has been added.                                                                                                                                              |
| p. 244      | B.1 Real-time OS has been added.                                                                                                                                                                                                        |
| p. 249      | APPENDIX D REVISION HISTORY has been added.                                                                                                                                                                                             |

The mark  $\star$  shows major revised points.

### PREFACE

| Readers                 | This manual has been prepared for user engineers who want to understand the functions of the $\mu$ PD78083 subseries and design and develop its application systems and programs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Caution                 | In the $\mu$ PD78083 Subseries, the $\mu$ PD78P083DU is not designed to maintain the reliability required for use in customers' mass-produced equipment. Please use this device only for experimentation or for evaluation of functions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Purpose                 | This manual is intended for users to understand the functions described in the Organization below.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Organization            | The $\mu$ PD78083 subseries manual is separated into two parts: this manual and the instruction edition (common to the 78K/0 Series).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                         | μPD78083 Subseries<br>User's Manual<br>(This Manual)78K/0 Series<br>User's Manual<br>InstructionPin functions0 CPU functionsInternal block functions0 Instruction setInterruptExplanation of each instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| How to Read This Manual | Before reading this manual, you should have general knowledge of electric and logic circuits and microcontrollers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                         | <ul> <li>○ For those who will be using this as a manual for the µPD78081(A), 78082(A), 78P083(A) and 78081(A2):</li> <li>→ The µPD78081, 78082, 78P083 are explained as being representative devices.</li> <li>In case this is used as a manual for the µPD78081(A), 78082(A), 78P083(A), or 78081(A2), please reread the product names as follows.</li> <li>µPD78081 → µPD78081(A) or µPD78081(A2)</li> <li>µPD78082 → µPD78082(A)</li> <li>µPD78P083 → µPD78P083(A)</li> <li>○ When you want to understand the functions in general:</li> <li>→ Read this manual in the order of the contents.</li> <li>○ To know the µPD78083 Subseries instruction function in detail:</li> <li>→ Refer to the <b>78K/0 Series User's Manual: Instructions (IEU-1372)</b></li> <li>○ How to interpret the register format:</li> <li>→ For the circled bit number, the bit name is defined as a reserved word in RA78K/0, and in CC78K/0, already defined in the header file named sfrbit.h.</li> <li>○ To know the electrical specifications of the µPD78083 Subseries:</li> <li>→ Refer to separately available Data Sheet.</li> </ul> |

○ To know application examples of the functions provided in the  $\mu$ PD78083 Subseries: → Refer to Application Note separately provided.

| Legend | Data representation weight<br>Active low representations<br>Note<br>Caution<br>Remarks<br>Numeral representations | :: | High digits on the left and low digits on the right<br>$\overrightarrow{\times\times\times}$ (line over the pin and signal names)<br>Description of note in the text.<br>Information requiring particular attention<br>Additional explanatory material<br>Binary $\times\times\times\times$ or $\times\times\times\times$ B<br>Decimal $\times\times\times\times$<br>Hexadecimal $\times\times\times\times$ H |
|--------|-------------------------------------------------------------------------------------------------------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                                                                                                                   |    | Hexadecimal XXXXH                                                                                                                                                                                                                                                                                                                                                                                             |

Examples of use in this manual are prepared for "Standard" quality level devices for general electronic equipment. In the case of examples of use in this manual for devices which meet "Special" quality level requirements, please use each device only after studying each part that is actual to be used, the circuitry and the quality level of each component before use.

### **Related Documents**

The related documents indicated in this publication may include preliminary versions. However, preliminary versions are not marked as such.

### • Related documents for *µ*PD78054 subseries

| Document name                                      | Document No.                                |          |             |
|----------------------------------------------------|---------------------------------------------|----------|-------------|
|                                                    | Japanese                                    | English  |             |
| μPD78083 Subseries User's Manual                   |                                             | U12176J  | This Manual |
| μPD78081, 78082 Data Sheet                         |                                             | U11415J  | U11415E     |
| μPD78P083 Data Sheet                               |                                             | U11006J  | U11006E     |
| μPD78081(A), 78082(A), 78081(A2) Data Sheet        | μPD78081(A), 78082(A), 78081(A2) Data Sheet |          |             |
| μPD78P083(A) Data Sheet                            | μPD78P083(A) Data Sheet                     |          |             |
| µPD78083 Subseries Special Function Register Table | IEM-5599                                    |          |             |
| 78K/0 Series User's Manual-Instruction             | IEU-849                                     | IEU-1372 |             |
| 78K/0 Series Instruction Table                     | U10903J                                     | _        |             |
| 78K/0 Series Instruction Set                       | U10904J                                     |          |             |
| 78K/0 Series Application Note                      | IEA-767                                     | U10182E  |             |

Caution: The above documents are subject to change without prior notice. Be sure to use the latest version document when starting design.

• Development Tool Documents (User's Manuals)

| Document name                                    | Document No.                                          |          |          |
|--------------------------------------------------|-------------------------------------------------------|----------|----------|
|                                                  |                                                       | Japanese | English  |
| RA78K Series Assembler Package                   | Operation                                             | EEU-809  | EEU-1399 |
|                                                  | Language                                              | EEU-815  | EEU-1404 |
| RA78K Series Structured Assembler Preprocessor   |                                                       | EEU-817  | EEU-1402 |
| RA78K0 Assembler Package                         | Structured assembly language                          | U11789J  | U11789E  |
|                                                  | Assembly language                                     | U11801J  | U11801E  |
|                                                  | Operation                                             | U11802J  | U11802E  |
| CC78K Series C Compiler                          | Operation                                             | EEU-656  | EEU-1280 |
|                                                  | Language                                              | EEU-655  | EEU-1284 |
| CC78K/0 C Compiler                               | Operation                                             | U11517J  | U11517E  |
|                                                  | Language                                              | U11518J  | U11518E  |
| CC78K/0 C Compiler Application Note              | Programming know-how                                  | EEA-618  | EEA-1208 |
| CC78K Series Library Source File                 |                                                       | EEU-777  | _        |
| PG-1500 PROM Programmer                          |                                                       | U11940J  | EEU-1335 |
| PG-1500 Controller PC-9800 Series (MS-DOS™) Base |                                                       |          | EEU-1291 |
| PG-1500 Controller IBM PC Series (PC DOS™) Base  |                                                       | EEU-5008 | U10540E  |
| IE-78000-R                                       |                                                       | EEU-810  | U11376E  |
| IE-78000-R-A                                     |                                                       | U10057J  | U10057E  |
| IE-78000-R-BK                                    |                                                       | EEU-867  | EEU-1427 |
| IE-78078-R-EM                                    |                                                       | U10775J  | U10775E  |
| EP-78083                                         |                                                       | EEU-5003 | EEU-1529 |
| SM78K0 System Simulator Windows™ Base            | Reference                                             | U10181J  | U10181E  |
| SM78K Series System Simulator                    | External component user open interface specifications | U10092J  | U10092E  |
| ID78K0 Integrated Debugger EWS Base              | Reference                                             | U11151J  | -        |
| ID78K0 Integrated Debugger PC Base               | Reference                                             | U11539J  | -        |
| ID78K0 Integrated Debugger Windows™ Base         | Guide                                                 | U11649J  | U11649E  |
| SD78K/0 Screen Debugger                          | Introduction                                          | EEU-852  | U10539E  |
| PC-9800 Series (MS-DOS) Base                     | Reference                                             | U10952J  | -        |
| SD78K/0 Screen Debugger                          | Introduction                                          | EEU-5024 | EEU-1414 |
| IBM PC/AT™ (PC DOS) Base                         | Reference                                             | U11279J  | U11279E  |

Caution: The above documents are subject to change without prior notice. Be sure to use the latest version document when starting design.

### • Documents for Embedded Software (User's Manual)

| Document name                                         |                                  | Document No. |   |
|-------------------------------------------------------|----------------------------------|--------------|---|
|                                                       | Japanese                         | English      |   |
| 78K/0 Series Real-Time OS                             | 78K/0 Series Real-Time OS Basics |              | _ |
|                                                       | Installation                     | U11536J      | — |
| Technicals                                            |                                  | U11538J      |   |
| OS for 78K/0 Series MX78K0                            | EEU-5010                         | _            |   |
| Fuzzy Knowledge Data Creation Tool                    | EEU-829                          | EEU-1438     |   |
| 78K/0, 78K/II, 87AD Series Fuzzy Inference Developmen | EEU-862                          | EEU-1444     |   |
| 78K/0 Series Fuzzy Inference Development Support Syst | EEU-858                          | EEU-1441     |   |
| 78K/0 Series Fuzzy Inference Development Support Syst | EEU-921                          | EEU-1458     |   |

### • Other Documents

| Document name                                                   | Document No. |         |
|-----------------------------------------------------------------|--------------|---------|
|                                                                 | Japanese     | English |
| IC PACKAGE MANUAL                                               | C10943X      |         |
| Semiconductor Device Mounting Technology Manual                 | C10535J      | C10535E |
| Quality Grade on NEC Semiconductor Devices                      | C11531J      | C11531E |
| Reliability Quality Control on NEC Semiconductor Devices        | C10983J      | C10983E |
| Electric Static Discharge (ESD) Test                            | MEM-539      |         |
| Semiconductor Devices Quality Assurance Guide                   | C11893J      | C11893E |
| Microcontroller Related Product Guide—Third Party Manufacturers | U11416J      | _       |

Caution: The above documents are subject to change without prior notice. Be sure to use the latest version document when starting design.

### CONTENTS

| 1AF16<br>1.1 |         | UTLINE                                                                                                                |
|--------------|---------|-----------------------------------------------------------------------------------------------------------------------|
| 1.1          |         | cations                                                                                                               |
| 1.3          |         | ing Information                                                                                                       |
| 1.4          |         | y Grade                                                                                                               |
| 1.5          |         | onfiguration (Top View)                                                                                               |
| 1.6          |         | Series Development                                                                                                    |
| 1.7          |         | Diagram                                                                                                               |
| 1.8          |         | e of Function                                                                                                         |
| 1.9          | Differe | ences between the $\mu$ PD78081, 78082 and 78P083, the $\mu$ PD78081(A), 78082(A) 3P083(A), and the $\mu$ PD78081(A2) |
|              | ER 2 P  | IN FUNCTION                                                                                                           |
| 2.1          | Pin Fu  | Inction List                                                                                                          |
|              | 2.1.1   | Normal operating mode pins                                                                                            |
|              | 2.1.2   | PROM programming mode pins (µPD78P083 only)                                                                           |
| 2.2          | Descr   | iption of Pin Functions                                                                                               |
|              | 2.2.1   | P00 to P03 (Port 0)                                                                                                   |
|              | 2.2.2   | P10 to P17 (Port 1)                                                                                                   |
|              | 2.2.3   | P30 to P37 (Port 3)                                                                                                   |
|              | 2.2.4   | P50 to P57 (Port 5)                                                                                                   |
|              | 2.2.5   | P70 to P72 (Port 7)                                                                                                   |
|              | 2.2.6   | P100 to P101 (Port 10)                                                                                                |
|              | 2.2.7   | AVREF                                                                                                                 |
|              | 2.2.8   | AVDD                                                                                                                  |
|              | 2.2.9   | AVss                                                                                                                  |
|              | 2.2.10  | RESET                                                                                                                 |
|              | 2.2.11  | X1 and X2                                                                                                             |
|              | 2.2.12  | VDD                                                                                                                   |
|              | 2.2.13  | Vss                                                                                                                   |
|              | 2.2.14  | Vpp (µPD78P083 only)                                                                                                  |
|              | 2.2.15  | IC (Mask ROM version only)                                                                                            |
|              | 2.2.16  | NC (44-pin plastic QFP versions only)                                                                                 |
| 2.3          | Pin In  | put/Output Circuits and Recommended Connection of Unused Pins                                                         |
| APTE         | ER 3 C  | PU ARCHITECTURE                                                                                                       |
| 3.1          |         | ry Spaces                                                                                                             |
|              | 3.1.1   | Internal program memory space                                                                                         |
|              | 3.1.2   | Internal data memory space                                                                                            |
|              | 3.1.3   | Special Function Register (SFR) area                                                                                  |
|              | 3.1.4   | Data memory addressing                                                                                                |
| 3.2          | Proce   | ssor Registers                                                                                                        |
|              | 3.2.1   | Control registers                                                                                                     |
|              | 3.2.2   | General registers                                                                                                     |

|            | 3.2.3   | Special Function Register (SFR)               | 37       |
|------------|---------|-----------------------------------------------|----------|
| 3.3        | Instruc | ction Address Addressing                      | 40       |
|            | 3.3.1   | Relative Addressing                           | 40       |
|            | 3.3.2   | Immediate addressing                          | 41       |
|            | 3.3.3   | Table indirect addressing                     | 42       |
|            | 3.3.4   | Register addressing                           | 43       |
| 3.4        | Opera   | nd Address Addressing                         | 44       |
|            | 3.4.1   | Implied addressing                            | 44       |
|            | 3.4.2   | Register addressing                           | 45       |
|            | 3.4.3   | Direct addressing                             | 46       |
|            | 3.4.4   | Short direct addressing                       | 47       |
|            | 3.4.5   | Special-Function Register (SFR) addressing    | 49       |
|            | 3.4.6   | Register indirect addressing                  | 50       |
|            | 3.4.7   | Based addressing                              | 51       |
|            | 3.4.8   | Based indexed addressing                      | 52       |
|            | 3.4.9   | Stack addressing                              | 52       |
|            |         |                                               |          |
| CHAPTE     | R 4 P   | ORT FUNCTIONS                                 | 53       |
| 4.1        | Port F  | unctions                                      | 53       |
| 4.2        | Port C  | onfiguration                                  | 55       |
|            | 4.2.1   | Port 0                                        | 55       |
|            | 4.2.2   | Port 1                                        | 57       |
|            | 4.2.3   | Port 3                                        | 58       |
|            | 4.2.4   | Port 5                                        | 59       |
|            | 4.2.5   | Port 7                                        | 60       |
|            | 4.2.6   | Port 10                                       | 62       |
| 4.3        |         | unction Control Registers                     | 63       |
| 4.4        | Port F  | unction Operations                            | 67       |
|            | 4.4.1   | Writing to input/output port                  | 67       |
|            | 4.4.2   | Reading from input/output port                | 67       |
|            | 4.4.3   | Operations on input/output port               | 67       |
|            |         |                                               |          |
|            |         |                                               | 69       |
| 5.1        |         | Generator Functions                           | 69       |
| 5.2        |         | Generator Configuration                       | 69       |
| 5.3        |         | Generator Control Register                    | 71       |
| 5.4        | -       | m Clock Oscillator                            | 73       |
|            | 5.4.1   | Main system clock oscillator                  | 73       |
|            | 5.4.2   | Scaler                                        | 75       |
| 5.5        |         | Generator Operations                          | 76       |
| 5.6        |         | Jing CPU Clock Settings                       | 77       |
|            | 5.6.1   | Time required for CPU clock switchover        | 77       |
|            | 5.6.2   | CPU clock switching procedure                 | 78       |
| СПУрте     |         | BIT TIMER/EVENT COUNTERS 5 AND 6              | 79       |
| 6.1        |         | imer/Event Counters 5 and 6 Functions         | 79<br>80 |
| 6.2        |         | Timer/Event Counters 5 and 6 Functions        | 80<br>82 |
| 6.2<br>6.3 |         | imer/Event Counters 5 and 6 Control Registers | 84       |
| 0.0        |         |                                               | 04       |

|      | 6.4  | 8-Bit Timer/Event Counters 5 and 6 Operations                  |
|------|------|----------------------------------------------------------------|
|      |      | 6.4.1 Interval timer operations                                |
|      |      | 6.4.2 External event counter operation                         |
|      |      | 6.4.3 Square-wave output                                       |
|      |      | 6.4.4 PWM output operations                                    |
|      | 6.5  | Cautions on 8-Bit Timer/Event Counters 5 and 6 10              |
|      |      |                                                                |
| СН   |      | R 7 WATCHDOG TIMER                                             |
|      | 7.1  | Watchdog Timer Functions                                       |
|      | 7.2  | Watchdog Timer Configuration                                   |
|      | 7.3  | Watchdog Timer Control Registers                               |
|      | 7.4  | Watchdog Timer Operations 10                                   |
|      |      | 7.4.1 Watchdog timer operation                                 |
|      |      | 7.4.2 Interval timer operation                                 |
| СН   |      | R 8 CLOCK OUTPUT CONTROL CIRCUIT                               |
| 0.11 | 8.1  | Clock Output Control Circuit Functions                         |
|      | 8.2  | Clock Output Control Circuit Configuration                     |
|      | 8.3  | Clock Output Function Control Registers                        |
|      | 0.5  |                                                                |
| СН   | ΑΡΤΕ | R 9 BUZZER OUTPUT CONTROL CIRCUIT 11                           |
|      | 9.1  | Buzzer Output Control Circuit Functions 11                     |
|      | 9.2  | Buzzer Output Control Circuit Configuration 11                 |
|      | 9.3  | Buzzer Output Function Control Registers 11                    |
| ~    |      |                                                                |
| Сп   |      | R 10 A/D CONVERTER                                             |
|      |      | A/D Converter Functions 11                                     |
|      |      | A/D Converter Configuration                                    |
|      |      | A/D Converter Control Registers                                |
|      | 10.4 | A/D Converter Operations 12                                    |
|      |      | 10.4.1 Basic operations of A/D converter                       |
|      |      | 10.4.2         Input voltage and conversion results         12 |
|      |      | 10.4.3 A/D converter operating mode                            |
|      | 10.5 | A/D Converter Cautions 13                                      |
| СН   | ΑΡΤΕ | R 11 SERIAL INTERFACE CHANNEL 2                                |
| •    | 11.1 | Serial Interface Channel 2 Functions                           |
|      | 11.2 | Serial Interface Channel 2 Configuration                       |
|      |      | Serial Interface Channel 2 Control Registers                   |
|      |      | Serial Interface Channel 2 Operation                           |
|      |      | 11.4.1 Operation stop mode                                     |
|      |      | 11.4.2 Asynchronous serial interface (UART) mode               |
|      |      | 11.4.3 3-wire serial I/O mode                                  |
|      |      |                                                                |
| СН   |      | R 12 INTERRUPT FUNCTION                                        |
|      |      | Interrupt Function Types 17                                    |
|      |      | Interrupt Sources and Configuration 17                         |
|      | 12.3 | Interrupt Function Control Registers 17                        |

| 12.4   | Interrupt Servicing Operations                              | 181        |  |  |  |
|--------|-------------------------------------------------------------|------------|--|--|--|
|        | 12.4.1 Non-maskable interrupt request acknowledge operation | 181        |  |  |  |
|        | 12.4.2 Maskable interrupt request acknowledge operation     | 184        |  |  |  |
|        | 12.4.3 Software interrupt request acknowledge operation     | 187        |  |  |  |
|        | 12.4.4 Multiple interrupt servicing                         | 187        |  |  |  |
|        | 12.4.5 Interrupt request reserve                            | 191        |  |  |  |
|        |                                                             |            |  |  |  |
|        | R 13 STANDBY FUNCTION                                       | 193        |  |  |  |
| 13.1   | Standby Function and Configuration                          | 193        |  |  |  |
|        | 13.1.1 Standby function                                     | 193        |  |  |  |
|        | 13.1.2 Standby function control register                    | 194        |  |  |  |
| 13.2   | Standby Function Operations                                 | 195        |  |  |  |
|        | 13.2.1 HALT mode                                            | 195        |  |  |  |
|        | 13.2.2 STOP mode                                            | 198        |  |  |  |
| СНАРТЕ | R 14 RESET FUNCTION                                         | 201        |  |  |  |
|        | Reset Function                                              | 201        |  |  |  |
| 14.1   |                                                             | 201        |  |  |  |
| CHAPTE | R 15 μPD78P083                                              | 205        |  |  |  |
|        | Memory Size Switching Register                              | 206        |  |  |  |
|        | PROM Programming                                            | 207        |  |  |  |
|        | 15.2.1 Operating modes                                      | 207        |  |  |  |
|        | 15.2.2 PROM write procedure                                 | 209        |  |  |  |
|        | 15.2.3 PROM reading procedure                               | 213        |  |  |  |
| 15.3   | Erasure Procedure (µPD78P083DU Only)                        | 214        |  |  |  |
|        | Opaque Film Masking the Window (µPD78P083DU Only)           | 214        |  |  |  |
|        | Screening of One-Time PROM Versions                         |            |  |  |  |
|        |                                                             |            |  |  |  |
|        | R 16 INSTRUCTION SET                                        | 215        |  |  |  |
| 16.1   | Legends Used in Operation List                              | 216        |  |  |  |
|        | 16.1.1 Operand identifiers and description methods          | 216        |  |  |  |
|        | 16.1.2 Description of "operation" column                    | 217        |  |  |  |
|        | 16.1.3 Description of "flag operation" column               | 217        |  |  |  |
| 16.2   | •                                                           | 218        |  |  |  |
| 16.3   | Instructions Listed by Addressing Type                      | 226        |  |  |  |
|        | NX A DEVELOPMENT TOOLS                                      | 231        |  |  |  |
| A.1    | Language Processing Software                                | 233        |  |  |  |
| A.2    | PROM Programming Tools                                      | 234        |  |  |  |
| /      | A.2.1 Hardware                                              | 234        |  |  |  |
|        | A.2.2 Software                                              | 234        |  |  |  |
| A.3    | Debugging Tools                                             | <b>235</b> |  |  |  |
|        | A.3.1 Hardware                                              | 235        |  |  |  |
|        | A.3.2 Software (1/3)                                        | 236        |  |  |  |
|        | A.3.2 Software (2/3)                                        | 237        |  |  |  |
|        | A.3.2 Software (3/3)                                        | 238        |  |  |  |
| A.4    | OS for IBM PC                                               | 239        |  |  |  |
|        |                                                             |            |  |  |  |

– iv –

 $\star$ 

|   | A.5   | System-Upgrade Method from Other In-Circuit Emulators to 78K/0 Series |     |
|---|-------|-----------------------------------------------------------------------|-----|
|   |       | In-Circuit Emulator                                                   | 240 |
| * | APPEN | DIX B EMBEDDED SOFTWARE                                               | 243 |
|   | B.1   | Real-time OS                                                          | 244 |
|   | B.2   | Fuzzy Inference Development Support System                            | 245 |
|   | APPEN | DIX C REGISTER INDEX                                                  | 247 |
|   | C.1   | Register Index                                                        | 247 |
| * |       |                                                                       |     |
|   | APPEN | DIX D REVISION HISTORY                                                | 249 |

### FIGURE (1/4)

| Fig. No. | Title                                                                      | Page |
|----------|----------------------------------------------------------------------------|------|
| 2-1      | Pin Input/Output Circuit of List                                           | 23   |
| 3-1      | Memory Map (μPD78081)                                                      | 25   |
| 3-2      | Memory Map (μPD78082)                                                      |      |
| 3-3      | Memory Map (μPD78P083)                                                     | 27   |
| 3-4      | Data Memory Addressing (μPD78081)                                          |      |
| 3-5      | Data Memory Addressing (µPD78082)                                          | 31   |
| 3-6      | Data Memory Addressing (µPD78P083)                                         | 32   |
| 3-7      | Program Counter Configuration                                              | 33   |
| 3-8      | Program Status Word Configuration                                          | 33   |
| 3-9      | Stack Pointer Configuration                                                | 35   |
| 3-10     | Data to be Saved to Stack Memory                                           | 35   |
| 3-11     | Data to be Reset from Stack Memory                                         | 35   |
| 3-12     | General Register Configuration                                             | 36   |
| 4-1      | Port Types                                                                 | 53   |
| 4-2      | P00 Block Diagram                                                          | 56   |
| 4-3      | P01 to P03 Block Diagram                                                   | 56   |
| 4-4      | P10 to P17 Block Diagram                                                   | 57   |
| 4-5      | P30 to P37 Block Diagram                                                   | 58   |
| 4-6      | P50 to P57 Block Diagram                                                   | 59   |
| 4-7      | P70 Block Diagram                                                          | 60   |
| 4-8      | P71 and P72 Block Diagram                                                  | 61   |
| 4-9      | P100 to P101 Block Diagram                                                 | 62   |
| 4-10     | Port Mode Register Format                                                  | 65   |
| 4-11     | Pull-Up Resistor Option Register Format                                    | 66   |
| 5-1      | Block Diagram of Clock Generator                                           | 70   |
| 5-2      | Processor Clock Control Register Format                                    | 71   |
| 5-3      | Oscillation Mode Selection Register Format                                 | 72   |
| 5-4      | Main System Clock Waveform due to Writing to OSMS                          |      |
| 5-5      | External Circuit of Main System Clock Oscillator                           | 73   |
| 5-6      | Examples of Oscillator with Bad Connection (1/2)                           | 74   |
| 5-7      | CPU Clock Switching                                                        | 78   |
| 6-1      | 8-Bit Timer/Event Counters 5 and 6 Block Diagram                           | 82   |
| 6-2      | Block Diagram of 8-Bit Timer/Event Counters 5 and 6 Output Control Circuit |      |
| 6-3      | Timer Clock Select Register 5 Format                                       |      |
| 6-4      | Timer Clock Select Register 6 Format                                       | 86   |
| 6-5      | 8-Bit Timer Mode Control Register 5 Format                                 | 87   |
| 6-6      | 8-Bit Timer Mode Control Register 6 Format                                 | 88   |
| 6-7      | Port Mode Register 10 Format                                               | 89   |
| 6-8      | 8-Bit Timer Mode Control Register Settings for Interval Timer Operation    | 90   |
| 6-9      | Interval Timer Operation Timings                                           | 91   |

### FIGURE (2/4)

| Fig. No. | Title                                                                          | Page |
|----------|--------------------------------------------------------------------------------|------|
| 6-10     | 8-Bit Timer Mode Control Register Setting for External Event Counter Operation | 93   |
| 6-11     | External Event Counter Operation Timings (with Rising Edge Specification)      | 93   |
| 6-12     | 8-Bit Timer Mode Control Register Settings for Square-Wave Output Operation    | 94   |
| 6-13     | 8-Bit Timer Mode Control Register Settings for PWM Output Operation            | 96   |
| 6-14     | PWM Output Operation Timing (Active high setting)                              | 97   |
| 6-15     | PWM Output Operation Timings (CRn0 = 00H, active high setting)                 | 97   |
| 6-16     | PWM Output Operation Timings (CRn0 = FFH, active high setting)                 | 98   |
| 6-17     | PWM Output Operation Timings (CRn0 changing, active high setting)              | 99   |
| 6-18     | 8-Bit Timer Registers 5 and 6 Start Timing                                     | 100  |
| 6-19     | External Event Counter Operation Timing                                        | 100  |
| 6-20     | Timing after Compare Register Change during Timer Count Operation              | 101  |
| 7-1      | Watchdog Timer Block Diagram                                                   | 105  |
| 7-2      | Timer Clock Select Register 2 Format                                           | 107  |
| 7-3      | Watchdog Timer Mode Register Format                                            | 108  |
| 8-1      | Remote Controlled Output Application Example                                   | 111  |
| 8-2      | Clock Output Control Circuit Block Diagram                                     | 112  |
| 8-3      | Timer Clock Select Register 0 Format                                           | 113  |
| 8-4      | Port Mode Register 3 Format                                                    | 114  |
| 9-1      | Buzzer Output Control Circuit Block Diagram                                    | 115  |
| 9-2      | Timer Clock Select Register 2 Format                                           | 117  |
| 9-3      | Port Mode Register 3 Format                                                    | 118  |
| 10-1     | A/D Converter Block Diagram                                                    | 120  |
| 10-2     | A/D Converter Mode Register Format                                             | 123  |
| 10-3     | A/D Converter Input Select Register Format                                     | 124  |
| 10-4     | External Interrupt Mode Register 1 Format                                      | 125  |
| 10-5     | A/D Converter Basic Operation                                                  | 127  |
| 10-6     | Relations between Analog Input Voltage and A/D Conversion Result               | 128  |
| 10-7     | A/D Conversion by Hardware Start                                               | 129  |
| 10-8     | A/D Conversion by Software Start                                               | 130  |
| 10-9     | Example of Method of Reducing Current Dissipation in Standby Mode              | 131  |
| 10-10    | Analog Input Pin Disposition                                                   | 132  |
| 10-11    | A/D Conversion End Interrupt Request Generation                                |      |
| 10-12    | Handling of AVDD Pin                                                           | 133  |
| 11-1     | Serial Interface Channel 2 Block Diagram                                       | 137  |
| 11-2     | Baud Rate Generator Block Diagram                                              | 138  |
| 11-3     | Serial Operating Mode Register 2 Format                                        | 140  |
| 11-4     | Asynchronous Serial Interface Mode Register Format                             | 141  |
| 11-5     | Asynchronous Serial Interface Status Register Format                           | 143  |
| 11-6     | Baud Rate Generator Control Register Format (1/2)                              | 144  |

### FIGURE (3/4)

| Fig. No. | Title                                                                          | Page |
|----------|--------------------------------------------------------------------------------|------|
| 11-6     | Baud Rate Generator Control Register Format (2/2)                              | 145  |
| 11-7     | Asynchronous Serial Interface Transmit/Receive Data Format                     | 157  |
| 11-8     | Asynchronous Serial Interface Transmission Completion Interrupt Request Timing | 159  |
| 11-9     | Asynchronous Serial Interface Reception Completion Interrupt Request Timing    | 160  |
| 11-10    | Receive Error Timing                                                           | 161  |
| 11-11    | State of the Receive Buffer Register (RXB) when Reception is Interrupted, and  |      |
|          | Generation/Non Generation of an Interrupt Request (INTSR)                      | 162  |
| 11-12    | 3-Wire serial I/O Mode Timing                                                  | 168  |
| 11-13    | Circuit of Switching in Transfer Bit Order                                     | 169  |
| 12-1     | Basic Configuration of Interrupt Function (1/2)                                | 173  |
| 12-1     | Basic Configuration of Interrupt Function (2/2)                                | 174  |
| 12-2     | Interrupt Request Flag Register Format                                         | 176  |
| 12-3     | Interrupt Mask Flag Register Format                                            | 177  |
| 12-4     | Priority Specify Flag Register Format                                          | 178  |
| 12-5     | External Interrupt Mode Register 0 Format                                      |      |
| 12-6     | External Interrupt Mode Register 1 Format                                      | 179  |
| 12-7     | Program Status Word Configuration                                              | 180  |
| 12-8     | Flowchart from Non-Maskable Interrupt Request Generation to Acknowledgment     | 182  |
| 12-9     | Non-Maskable Interrupt Request Acknowledge Timing                              | 182  |
| 12-10    | Non-Maskable Interrupt Request Acknowledge Operation                           | 183  |
| 12-11    | Interrupt Request Acknowledge Processing Algorithm                             | 185  |
| 12-12    | Interrupt Request Acknowledge Timing (Minimum Time)                            | 186  |
| 12-13    | Interrupt Request Acknowledge Timing (Maximum Time)                            | 186  |
| 12-14    | Example of Multiple Interrupt (1/2)                                            | 189  |
| 12-14    | Example of Multiple Interrupt (2/2)                                            | 190  |
| 12-15    | Interrupt Request Hold                                                         | 192  |
| 13-1     | Oscillation Stabilization Time Select Register Format                          | 194  |
| 13-2     | HALT Mode Clear upon Interrupt Generation                                      | 196  |
| 13-3     | HALT Mode Release by RESET Input                                               | 197  |
| 13-4     | STOP Mode Release by Interrupt Generation                                      | 199  |
| 13-5     | Release by STOP Mode RESET Input                                               | 200  |
| 14-1     | Block Diagram of Reset Function                                                | 201  |
| 14-2     | Timing of Reset Input by RESET Input                                           | 202  |
| 14-3     | Timing of Reset due to Watchdog Timer Overflow                                 | 202  |
| 14-4     | Timing of Reset Input in STOP Mode by RESET Input                              | 202  |
| 15-1     | Memory Size Switching Register Format                                          | 206  |
| 15-2     | Page Program Mode Flowchart                                                    | 209  |
| 15-3     | Page Program Mode Timing                                                       | 210  |
| 15-4     | Byte Program Mode Flowchart                                                    | 211  |
| 15-5     | Byte Program Mode Timing                                                       | 212  |

### FIGURE (4/4)

| Fig. No. | Title                                      | Page |
|----------|--------------------------------------------|------|
| 15-6     | PROM Read Timing                           | 213  |
| A-1      | Development Tool Configuration             | 232  |
| A-2      | EV-9200G-44 Drawing (For Reference Only)   | 241  |
| A-3      | EV-9200G-44 Footprint (For Reference Only) | 242  |

### TABLE (1/2)

| Table. No. | Title                                                                                                                            | Page |
|------------|----------------------------------------------------------------------------------------------------------------------------------|------|
| 1-1        | Differences between the $\mu$ PD78081, 78082 and 78P083, the $\mu$ PD78081(A), 78082(A) and 78P083(A), and the $\mu$ PD78081(A2) | 13   |
| 2-1        | Type of Input/Output Circuit of Each Pin                                                                                         | 22   |
| 3-1        | Vector Table                                                                                                                     | 28   |
| 3-2        | Special-Function Register List (1/2)                                                                                             |      |
| 3-2        | Special-Function Register List (2/2)                                                                                             |      |
| 4-1        | Port Functions                                                                                                                   | 54   |
| 4-2        | Port Configuration                                                                                                               | 55   |
| 4-3        | Port Mode Register and Output Latch Settings when Using Dual-Fucntions                                                           | 64   |
| 5-1        | Clock Generator Configuration                                                                                                    | 69   |
| 5-2        | Maximum Time Required for CPU Clock Switchover                                                                                   | 77   |
| 6-1        | Timer/Event Counter Types and Functions                                                                                          | 79   |
| 6-2        | 8-Bit Timer/Event Counters 5 and 6 Interval Times                                                                                | 80   |
| 6-3        | 8-Bit Timer/Event Counters 5 and 6 Square-Wave Output Ranges                                                                     | 81   |
| 6-4        | 8-Bit Timer/Event Counters 5 and 6 Configurations                                                                                | 82   |
| 6-5        | 8-Bit Timer/Event Counters 5 and 6 Interval Times                                                                                | 92   |
| 6-6        | 8-Bit Timer/Event Counters 5 and 6 Square-Wave Output Ranges                                                                     | 95   |
| 7-1        | Watchdog Timer Overrun Detection Times                                                                                           | 103  |
| 7-2        | Interval Times                                                                                                                   | 104  |
| 7-3        | Watchdog Timer Configuration                                                                                                     | 105  |
| 7-4        | Watchdog Timer Overrun Detection Time                                                                                            | 109  |
| 7-5        | Interval Timer Interval Time                                                                                                     | 110  |
| 8-1        | Clock Output Control Circuit Configuration                                                                                       | 112  |
| 9-1        | Buzzer Output Control Circuit Configuration                                                                                      | 115  |
| 10-1       | A/D Converter Configuration                                                                                                      | 119  |
| 11-1       | Serial Interface Channel 2 Configuration                                                                                         | 136  |
| 11-2       | Serial Interface Channel 2 Operating Mode Settings                                                                               | 142  |
| 11-3       | Relation between Main System Clock and Baud Rate                                                                                 | 146  |
| 11-4       | Relation between ASCK Pin Input Frequency and Baud Rate (When BRGC is set to 00H                                                 |      |
| 11-5       | Relation between Main System Clock and Baud Rate                                                                                 | -    |
| 11-6       | Relation between ASCK Pin Input Frequency and Baud Rate (When BRGC is set to 00H                                                 |      |
| 11-7       | Receive Error Causes                                                                                                             | -    |

### TABLE (2/2)

| Table. No. | Title                                                                       | Page |
|------------|-----------------------------------------------------------------------------|------|
| 12-1       | Interrupt Source List                                                       | 172  |
| 12-2       | Various Flags Corresponding to Interrupt Request Sources                    | 175  |
| 12-3       | Times from Maskable Interrupt Request Generation to Interrupt Service       | 184  |
| 12-4       | Interrupt Request Enabled for Multiple Interrupt during Interrupt Servicing | 188  |
| 13-1       | HALT Mode Operating Status                                                  | 195  |
| 13-2       | Operation after HALT Mode Release                                           | 197  |
| 13-3       | STOP Mode Operating Status                                                  | 198  |
| 13-4       | Operation after STOP Mode Release                                           | 200  |
| 14-1       | Hardware Status after Reset (1/2)                                           | 203  |
| 14-1       | Hardware Status after Reset (2/2)                                           | 204  |
| 15-1       | Differences between the $\mu$ PD78P083 and Mask ROM Versions                | 205  |
| 15-2       | Examples of Memory Size Switching Register Settings                         | 206  |
| 15-3       | PROM Programming Operating Modes                                            | 207  |
| 16-1       | Operand Identifiers and Description Methods                                 | 216  |
| A-1        | System-Up Method from Other In-Circuit Emulator to IE-78000-R               | 240  |
| A-2        | System-Up Method from Other In-Circuit Emulator to IE-78000-R-A             | 240  |

[MEMO]

### **CHAPTER 1 OUTLINE**

#### 1.1 Features

On-chip ROM and RAM

| Туре        | Program Memory   | Data Memory               |  |
|-------------|------------------|---------------------------|--|
| Part Number | (ROM)            | (Internal High-Speed RAM) |  |
| μPD78081    | 8 Kbytes         | 256 bytes                 |  |
| μPD78082    | 16 Kbytes        | 384 bytes                 |  |
| μPD78P083   | 24 Kbytes (Note) | 512 bytes (Note)          |  |

**Note** The capacities of internal PROM and internal high-speed RAM can be changed by means of the memory size switching register (IMS).

Instruction execution time changeable from high speed (0.4 μs: In main system clock 5.0 MHz operation) to low speed (12.8 μs: In main system clock 5.0 MHz operation)

1

- O Instruction set suited to system control
  - Bit manipulation possible in all address spaces
  - Multiply and divide instructions
- O 33 I/O ports

\*

- O 8-bit resolution A/D converter: 8 channels
- O Serial interface: 1 channel
  - 3-wire serial I/O/UART mode: 1 channel
- O Timer: 3 channels
  - 8-bit timer/event counter : 2 channels
  - Watchdog timer: 1 channel
- O Vectored Interrupt Source : 13
- Supply voltage: VDD = 1.8 to 5.5 V

### **1.2 Applications**

### μ**PD78081, 78082, 78P083:**

Airbags, CRT displays, keyboards, air conditioners, hot water dispensers, boilers, fan heaters, dashboards, etc.

### **★** μPD78081(A), 78082(A), 78P083(A), 78081(A2):

Automobile electrical control devices, gas detector cutoff devices, various safety devices, etc.

### ★ 1.3 Ordering Information

| Part number                            | Package                                           | Internal ROM  |
|----------------------------------------|---------------------------------------------------|---------------|
| μPD78081CU-×××                         | 42-pin plastic shrink DIP (600 mil)               | Mask ROM      |
| μPD78081GB-×××-3B4                     | 44-pin plastic QFP (10 $\times$ 10 mm)            | Mask ROM      |
| $\mu$ PD78081GB- $\times$ ××-3BS-MTX   | 44-pin plastic QFP (10 $\times$ 10 mm)            | Mask ROM      |
| $\mu$ PD78082CU- $\times$ ××           | 42-pin plastic shrink DIP (600 mil)               | Mask ROM      |
| μPD78082GB-×××-3B4                     | 44-pin plastic QFP (10 $\times$ 10 mm)            | Mask ROM      |
| $\mu$ PD78082GB- $\times$ ××-3BS-MTX   | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Mask ROM      |
| μPD78P083CU                            | 42-pin plastic shrink DIP (600 mil)               | One-Time PROM |
| μPD78P083DU                            | 42-pin ceramic shrink DIP (with window) (600 mil) | EPROM         |
| μPD78P083GB-3B4                        | 44-pin plastic QFP (10 $	imes$ 10 mm)             | One-Time PROM |
| $\mu$ PD78P083GB-3BS-MTX               | 44-pin plastic QFP (10 $	imes$ 10 mm)             | One-Time PROM |
| μPD78081GB(A)-×××-3B4                  | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Mask ROM      |
| μPD78082GB(A)-×××-3B4                  | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Mask ROM      |
| μPD78P083CU(A)                         | 42-pin plastic shrink DIP (600 mil)               | One-Time PROM |
| μPD78P083GB(A)-3B4                     | 44-pin plastic QFP (10 $	imes$ 10 mm)             | One-Time PROM |
| µPD78P083GB(A)-3BS-MTX <sup>Note</sup> | 44-pin plastic QFP (10 $\times$ 10 mm)            | One-Time PROM |
| μPD78081GB(A2)-×××-3B4                 | 44-pin plastic QFP (10 $\times$ 10 mm)            | Mask ROM      |

Note Under development

**Remark** ××× indicates ROM code suffix.

### ★ 1.4 Quality Grade

| Part number                            | Package                                           | Quality grade  |
|----------------------------------------|---------------------------------------------------|----------------|
| μPD78081CU-×××                         | 42-pin plastic shrink DIP (600 mil)               | Standard       |
| μPD78081GB-×××-3B4                     | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Standard       |
| $\mu$ PD78081GB-×××-3BS-MTX            | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Standard       |
| $\mu$ PD78082CU- $\times$ ××           | 42-pin plastic shrink DIP (600 mil)               | Standard       |
| μPD78082GB-×××-3B4                     | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Standard       |
| $\mu$ PD78082GB- $\times$ ××-3BS-MTX   | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Standard       |
| μPD78P083CU                            | 42-pin plastic shrink DIP (600 mil)               | Standard       |
| μPD78P083DU                            | 42-pin ceramic shrink DIP (with window) (600 mil) | Not applicable |
| μPD78P083GB-3B4                        | 44-pin plastic QFP (10 $\times$ 10 mm)            | Standard       |
| $\mu$ PD78P083GB-3BS-MTX               | 44-pin plastic QFP (10 $\times$ 10 mm)            | Standard       |
| μPD78081GB(A)-×××-3B4                  | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Special        |
| μPD78082GB(A)-×××-3B4                  | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Special        |
| μPD78P083CU(A)                         | 42-pin plastic shrink DIP (600 mil)               | Special        |
| μPD78P083GB(A)-3B4                     | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Special        |
| µPD78P083GB(A)-3BS-MTX <sup>Note</sup> | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Special        |
| μPD78081GB(A)-×××-3B4                  | 44-pin plastic QFP (10 $	imes$ 10 mm)             | Special        |

Note Under planning

Please refer to "Quality grade on NEC Semiconductor Devices" (Document number C11531E) published by NEC Corporation to know the specification of quality grade on the devices and its recommended applications.

### 1.5 Pin Configuration (Top View)

(1) Normal operating mode

42-pin plastic shrink DIP (600 mil)

 $\mu$ PD78081CU-xxx, 78082CU-xxx, 78P083CU, 78P083CU(A) **42-pin ceramic shrink DIP (with window) (600 mil)**  $\mu$ PD78P083DU



Cautions 1. Be sure to connect IC (Internally Connected) pin to Vss directly.

- 2. Connect AVDD pin to VDD.
- 3. Connect AVss pin to Vss.

**Remark** Pin connection in parentheses is intended for the  $\mu$ PD78P083.

 44-pin plastic QFP (10 × 10 mm) μPD78081GB-xxx-3B4, 78081GB-xxx-3BS-MTX μPD78082GB-xxx-3B4, 78082GB-xxx-3BS-MTX μPD78P083GB-3B4, 78P083GB-3BS-MTX μPD78081GB(A)-xxx-3B4, 78082GB(A)-xxx-3B4 μPD78P083GB(A)-3B4, 78P083GB(A)-3BS-MTX<sup>Note</sup> μPD78P081GB(A2)-xxx-3B4



Note Under development

- Cautions 1. Be sure to connect IC (Internally Connected) pin to Vss directly.
  - 2. Connect AVDD pin to VDD.
  - 3. Connect AVss pin to Vss.
  - 4. Connect NC pin to Vss for noise protection (It can be left open).

**Remark** Pin connection in parenthesis is intended for the  $\mu$ PD78P083.

### **Pin Identifications**

| ASCK: Asynchronous Serial ClockPCL: Programmable ClockAVDD: Analog Power SupplyRESET: ResetAVREF: Analog Reference VoltageRxD: Receive DataAVss: Analog GroundSCK2: Serial ClockBUZ: Buzzer ClockSl2: Serial Input |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AVREF:Analog Reference VoltageRxD:Receive DataAVss:Analog GroundSCK2:Serial ClockBUZ:Buzzer ClockSl2:Serial Input                                                                                                  |
| AVss: Analog GroundSCK2: Serial ClockBUZ: Buzzer ClockSl2: Serial Input                                                                                                                                            |
| BUZ : Buzzer Clock SI2 : Serial Input                                                                                                                                                                              |
|                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                    |
| IC : Internally Connected SO2 : Serial Output                                                                                                                                                                      |
| INTP1 to INTP3 : Interrupt from Peripherals TI5, TI6 : Timer Input                                                                                                                                                 |
| NC : Non-connection TO5 to TO6 : Timer Output                                                                                                                                                                      |
| P00 to P03 : Port 0 TxD : Transmit Data                                                                                                                                                                            |
| P10 to P17 : Port 1 VDD : Power Supply                                                                                                                                                                             |
| P30 to P37 : Port 3 VPP : Programming Power Supply                                                                                                                                                                 |
| P50 to P57 : Port 5 Vss : Ground                                                                                                                                                                                   |
| P70 to P72 : Port 7 X1, X2 : Crystal (Main System Clock)                                                                                                                                                           |

- (2) PROM programming mode
  - **42-pin plastic shrink DIP (600 mil)** μPD78P083CU, 78P083CU(A)
  - 42-pin ceramic shrink DIP (with window) (600 mil) μPD78P083DU



- Cautions 1. (L) : Individually connect to Vss via a pull-down resistor.
  - 2. Vss : Connect to the ground.
  - 3. RESET: Set to the low level.
  - 4. Open : Do not connect anything.

 44-pin plastic QFP (10 × 10 mm) μPD78P083GB-3B4, 78P083GB-3BS-MTX μPD78P083GB(A)-3B4, 78P083GB(A)-3BS-MTX<sup>Note</sup>



| Note | Under development |  |
|------|-------------------|--|
|------|-------------------|--|

| Cautions 1. (L) | : Connect individually to Vss via a p | ull-down resistor. |
|-----------------|---------------------------------------|--------------------|
|-----------------|---------------------------------------|--------------------|

- 2. Vss : Connect to the ground.
- 3. **RESET** : Set to the low level.
- 4. Open : Do not connect anything.

| A0 to A14 | : Address Bus   | RESET | : Reset                    |
|-----------|-----------------|-------|----------------------------|
| CE        | : Chip Enable   | Vdd   | : Power Supply             |
| D0 to D7  | : Data Bus      | Vpp   | : Programming Power Supply |
| OE        | : Output Enable | Vss   | : Ground                   |
| PGM       | : Program       |       |                            |

#### 1.6 78K/0 Series Development

The following shows the 78K/0 Series products development. Subseries names are shown inside frames.





| Function           |            | ROM        | Timer |        |       | 8-bit | 10-bit | 8-bit | Serial interface | I/O                                  | Vdd | External      |           |
|--------------------|------------|------------|-------|--------|-------|-------|--------|-------|------------------|--------------------------------------|-----|---------------|-----------|
| Subseries name     |            | capacity   | 8-bit | 16-bit | Watch | WDT   | A/D    | A/D   | D/A              | Senar internace                      | 1/0 | MIN.<br>value | expansio  |
| Control            | μPD78075B  | 32K to 40K | 4 ch  | 1 ch   | 1 ch  | 1 ch  | 8 ch   | —     | 2 ch             | 3 ch (UART: 1 ch)                    | 88  | 1.8 V         | Available |
|                    | μPD78078   | 48K to 60K |       |        |       |       |        |       |                  |                                      |     |               |           |
|                    | μPD78070A  | _          |       |        |       |       |        |       |                  |                                      | 61  | 2.7 V         | 1         |
|                    | μPD780018  | 48K to 60K |       |        |       |       |        |       | _                | 2 ch (Time division<br>3-wire: 1 ch) | 88  |               |           |
|                    | μPD780058  | 24K to 60K | 2 ch  |        |       |       |        |       | 2 ch             | 3 ch (Time division<br>UART: 1 ch)   | 68  | 1.8 V         | _         |
|                    | μPD78058F  | 48K to 60K |       |        |       |       |        |       |                  | 3 ch (UART: 1 ch)                    | 69  | 2.7 V         | -         |
|                    | μPD78054   | 16K to 60K |       |        |       |       |        |       |                  |                                      |     | 2.0 V         | 1         |
|                    | μPD780034  | 8K to 32K  |       |        |       |       | _      | 8 ch  | _                | 3 ch (UART: 1 ch, Time               | 51  | 1.8 V         | 1         |
|                    | μPD780024  |            |       |        |       |       | 8 ch   | _     |                  | division 3-wire: 1 ch)               |     |               |           |
|                    | μPD78014H  |            |       |        |       |       |        |       |                  | 2 ch                                 | 53  |               |           |
|                    | μPD78018F  | 8K to 60K  |       |        |       |       |        |       |                  |                                      |     |               |           |
|                    | μPD78014   | 8K to 32K  |       |        |       |       |        |       |                  |                                      |     | 2.7 V         |           |
|                    | μPD780001  | 8K         |       | _      | —     |       |        |       |                  | 1 ch                                 | 39  |               | _         |
|                    | μPD78002   | 8K to 16K  |       |        | 1 ch  |       | _      |       |                  |                                      | 53  |               | Available |
|                    | μPD78083   |            |       |        | _     |       | 8 ch   |       |                  | 1 ch (UART: 1 ch)                    | 33  | 1.8 V         | -         |
| Inverter           | μPD780964  | 8K to 32K  | 3 ch  | Note   | _     | 1 ch  | _      | 8 ch  | _                | 2 ch (UART: 2 ch)                    | 47  | 2.7 V         | Available |
| control            | µPD780924  |            |       |        |       |       | 8 ch   | —     |                  |                                      |     |               |           |
| FIP driving        | μPD780208  | 32K to 60K | 2 ch  | 1 ch   | 1 ch  | 1 ch  | 8 ch   | _     | —                | 2 ch                                 | 74  | 2.7 V         | -         |
|                    | μPD780228  | 48K to 60K | 3 ch  | _      | —     |       |        |       |                  | 1 ch                                 | 72  | 4.5 V         |           |
|                    | μPD78044H  | 32K to 48K | 2 ch  | 1 ch   | 1 ch  |       |        |       |                  |                                      | 68  | 2.7 V         | 1         |
|                    | μPD78044F  | 16K to 40K |       |        |       |       |        |       |                  | 2 ch                                 |     |               |           |
| LCD<br>driving     | μPD780308  | 48K to 60K | 2 ch  | 1 ch   | 1 ch  | 1 ch  | 8 ch   | _     | _                | 3 ch (Time division<br>UART: 1 ch)   | 57  | 2.0 V         | _         |
|                    | μPD78064B  | 32K        |       |        |       |       |        |       |                  | 2 ch (UART: 1 ch)                    |     |               |           |
|                    | μPD78064   | 16K to 32K |       |        |       |       |        |       |                  |                                      |     |               |           |
| IEBus<br>supported | μPD78098   | 32K to 60K | 2 ch  | 1 ch   | 1 ch  | 1 ch  | 8 ch   |       | 2 ch             | 3 ch (UART: 1 ch)                    | 69  | 2.7 V         | Available |
| LV                 | μPD78P0914 | 32K        | 6 ch  |        |       | 1 ch  | 8 ch   |       |                  | 2 ch                                 | 54  | 4.5 V         | Available |

### The following table shows the differences among subseries functions.

Note 10 bits timer: 1 channel

### 1.7 Block Diagram



**Remarks 1.** The internal ROM and high-speed RAM capacities depend on the product. **2.** Pin connection in parentheses is intended for the  $\mu$ PD78P083.

### **1.8 Outline of Function**

|                               | Part Number    | μ <b>ΡD78081</b>                                                                       | μ <b>PD78082</b> | μ <b>PD78083</b>          |  |  |  |  |
|-------------------------------|----------------|----------------------------------------------------------------------------------------|------------------|---------------------------|--|--|--|--|
| ltem                          |                |                                                                                        |                  |                           |  |  |  |  |
| Internal mer                  | mory ROM       | Mask ROM                                                                               | PROM             |                           |  |  |  |  |
|                               |                | 8 Kbytes                                                                               | 16 Kbytes        | 24 Kbytes <sup>Note</sup> |  |  |  |  |
|                               | High-speed RAM | 256 bytes                                                                              | 384 bytes        | 512 bytes <sup>Note</sup> |  |  |  |  |
| Memory spa                    | ace            | 64 Kbytes                                                                              |                  |                           |  |  |  |  |
| General reg                   | ister          | 8 bits $\times$ 32 registers (8 bits $\times$ 8 registers $\times$ 4 banks)            |                  |                           |  |  |  |  |
| Instruction cycle             |                | Instruction execution time variable function is integrated.                            |                  |                           |  |  |  |  |
|                               |                | 0.4 μs/0.8 μs/1.6 μs/3.2 μs/6.4 μs/12.8 μs (@5.0-MHz operation with main system clock) |                  |                           |  |  |  |  |
| Instruction a                 | set            | 16-bit operation                                                                       |                  |                           |  |  |  |  |
|                               |                | <ul> <li>Multiply/divide (8 bits × 8 bits, 16 bits ÷ 8 bits)</li> </ul>                |                  |                           |  |  |  |  |
|                               |                | <ul> <li>Bit manipulation (set, reset, test, Boolean operation)</li> </ul>             |                  |                           |  |  |  |  |
|                               |                | BCD adjust, etc.                                                                       |                  |                           |  |  |  |  |
| I/O ports                     |                | Total : 33                                                                             |                  |                           |  |  |  |  |
|                               |                | CMOS input : 1                                                                         |                  |                           |  |  |  |  |
|                               |                | CMOS input/output : 32                                                                 |                  |                           |  |  |  |  |
| A/D convert                   | er             | <ul> <li>8-bit resolution × 8 channels</li> </ul>                                      |                  |                           |  |  |  |  |
| Serial interf                 | ace            | 3-wire serial I/O/UART mode selectable: 1 channel                                      |                  |                           |  |  |  |  |
| Timer                         |                | 8-bit timer/event counter: 2 channels                                                  |                  |                           |  |  |  |  |
|                               |                | Watchdog timer: 1 channel                                                              |                  |                           |  |  |  |  |
| Timer outpu                   | t              | 2 pins (8-bit PWM output enable)                                                       |                  |                           |  |  |  |  |
| Clock output                  | t              | 19.5 kHz, 39.1 kHz, 78.1 kHz, 156 kHz, 313 kHz, 625 kHz, 1.25 MHz, 2.5 MHz,            |                  |                           |  |  |  |  |
|                               |                | and 5.0 MHz (@ 5.0-MHz operation with main system clock)                               |                  |                           |  |  |  |  |
| Buzzer outp                   | out            | 1.2 kHz, 2.4 kHz, 4.9 kHz, and 9.8 kHz                                                 |                  |                           |  |  |  |  |
|                               |                | (@ 5.0-MHz operation with main system clock)                                           |                  |                           |  |  |  |  |
| Vectored                      | Maskable       | Internal : 8 external : 3                                                              |                  |                           |  |  |  |  |
| interrupt                     | Non-maskable   | Internal : 1                                                                           |                  |                           |  |  |  |  |
| source                        | Software       | 1                                                                                      |                  |                           |  |  |  |  |
| Supply voltage                |                | V <sub>DD</sub> = 1.8 to 5.5 V                                                         |                  |                           |  |  |  |  |
| Operating ambient temperature |                | $T_{A} = -40$ to $+85^{\circ}C$                                                        |                  |                           |  |  |  |  |
| Package                       |                | <ul> <li>42-pin plastic shrink DIP (600 mil)</li> </ul>                                |                  |                           |  |  |  |  |
|                               |                | • 44-pin plastic QFP (10 $	imes$ 10 mm)                                                |                  |                           |  |  |  |  |
|                               |                | <ul> <li>42-pin ceramic shrink DIP (with window) (600 mil) (µPD78P083 only)</li> </ul> |                  |                           |  |  |  |  |

**Note** Internal PROM and high-speed RAM capacities can be changed by setting the internal memory size switching register (IMS).

 $\star$ 

# 1.9 Differences between the $\mu$ PD78081, 78082 and 78P083, the $\mu$ PD78081(A), 78082(A) and 78P083(A), and the $\mu$ PD78081(A2)

# Table 1-1 Differences between the $\mu$ PD78081, 78082 and 78P083, the $\mu$ PD78081(A), 78082(A) and 78P083(A), and the $\mu$ PD78081(A2)

| Part Number                                                           | μPD78081                        | μPD78081(A)  | μPD78081(A2)                                 |  |  |
|-----------------------------------------------------------------------|---------------------------------|--------------|----------------------------------------------|--|--|
|                                                                       | μPD78082                        | μPD78082(A)  |                                              |  |  |
| Item                                                                  | μPD78P083                       | μPD78P083(A) |                                              |  |  |
| Quality grade                                                         | Standard                        | Special      |                                              |  |  |
| Supply voltage                                                        | V <sub>DD</sub> = 1.8 to 5.5 V  |              | V <sub>DD</sub> = 4.5 to 5.5 V               |  |  |
| Operating ambient temperature                                         | $T_{A} = -40$ to $+85^{\circ}C$ |              | $T_A = -40 \text{ to } +125^{\circ}\text{C}$ |  |  |
| Electrical specifications Please refer to the individual data sheets. |                                 |              |                                              |  |  |

★

[MEMO]

# **CHAPTER 2 PIN FUNCTION**

# 2.1 Pin Function List

# 2.1.1 Normal operating mode pins

# (1) Port pins

| Pin Name | Input/Output |                           | Function                           | After Reset | Alternate Function |
|----------|--------------|---------------------------|------------------------------------|-------------|--------------------|
| P00      | Input        | Port 0                    | Input only                         | Input       | _                  |
| P01      | Input/output | 4-bit input/output port   | Input/output is specifiable        | Input       | INTP1              |
| P02      | _            |                           | bit-wise. When used as the         |             | INTP2              |
| P03      | _            |                           | input port, it is possible to      |             | INTP3              |
|          |              |                           | connect a pull-up resistor by      |             |                    |
|          |              |                           | software.                          |             |                    |
| P10-P17  | Input/output | Port 1                    | 1                                  | Input       | ANI0-ANI7          |
|          |              | 8-bit input/output port   |                                    |             |                    |
|          |              | Input/output is specifiab | le bit-wise.                       |             |                    |
|          |              | When used as the input    | t port, it is possible to connect  |             |                    |
|          |              | a pull-up resistor by sof | tware. Note                        |             |                    |
| P30-P34  | Input/output | Port 3                    |                                    | Input       | _                  |
| P35      | _            | 8-bit input/output port   |                                    |             | PCL                |
| P36      | _            | Input/output is specifiab | le bit-wise.                       |             | BUZ                |
| P37      |              | When used as the input    | It port, it is possible to connect |             | _                  |
|          |              | a pull-up resistor by sof | tware.                             |             |                    |
| P50-P57  | Input/output | Port 5                    |                                    | Input       | _                  |
|          |              | 8-bit input/output port   |                                    |             |                    |
|          |              | A maximum of 7 out of     | 8 ports can drive LEDs directly.   |             |                    |
|          |              | Input/output is specifiab | le bit-wise.                       |             |                    |
|          |              | When used as the input    | t port, it is possible to connect  |             |                    |
|          |              | a pull-up resistor by sof | tware.                             |             |                    |
| P70      | Input/output | Port 7                    |                                    | Input       | SI2/RxD            |
| P71      |              | 3-bit input/output port   |                                    |             | SO2/TxD            |
| P72      |              | Input/output is specifiab | le bit-wise.                       |             | SCK2/ASCK          |
|          |              | When used as the input    | t port, it is possible to connect  |             |                    |
|          |              | a pull-up resistor by sof | tware.                             |             |                    |
| P100     | Input/output | Port 10                   | Input                              | TI5/TO5     |                    |
| P101     |              | 2-bit input/output port   |                                    |             | TI6/TO6            |
|          |              | Input/output is specifiab | le bit-wise.                       |             |                    |
|          |              | When used as the input    | t port, it is possible to connect  |             |                    |
|          |              | a pull-up resistor by sof | tware.                             |             |                    |

**Note** When P10/ANI0-P17/ANI7 pins are used as the analog inputs for the A/D converter, set the port 1 to the input mode. The on-chip pull-up resistor is automatically disabled.

# (2) Pins other than port pins

| Pin Name  | Input/Output | Function                                                      | After Reset | Alternate Function |
|-----------|--------------|---------------------------------------------------------------|-------------|--------------------|
| INTP1     | Input        | External interrupt request input by which the active edge     | P01         |                    |
| INTP2     |              | (rising edge, falling edge, or both rising and falling edges) |             | P02                |
| INTP3     |              | can be specified.                                             |             | P03                |
| SI2       | Input        | Serial interface serial data input.                           | Input       | P70/RxD            |
| SO2       | Output       | Serial interface serial data output.                          | Input       | P71/TxD            |
| SCK2      | Input/output | Serial interface serial clock input/output.                   | Input       | P72/ASCK           |
| RxD       | Input        | Asynchronous serial interface serial data input.              | Input       | P70/SI2            |
| TxD       | Output       | Asynchronous serial interface serial data output.             | Input       | P71/SO2            |
| ASCK      | Input        | Asynchronous serial interface serial clock input.             | Input       | P72/SCK2           |
| TI5       | Input        | External count clock input to 8-bit timer (TM5).              | Input       | P100/TO5           |
| TI6       |              | External count clock input to 8-bit timer (TM6).              |             | P101/TO6           |
| TO5       | Output       | 8-bit timer output. (also used for 8-bit PWM output)          | Input       | P100/TI5           |
| TO6       |              |                                                               |             | P101/TI6           |
| PCL       | Output       | Clock output. (for main system clock trimming)                | Input       | P35                |
| BUZ       | Output       | Buzzer output.                                                | Input       | P36                |
| ANI0-ANI7 | Input        | A/D converter analog input.                                   | Input       | P10-P17            |
| AVREF     | Input        | A/D converter reference voltage input.                        | -           | -                  |
| AVdd      | -            | A/D converter analog power supply. Connected to VDD.          | -           | -                  |
| AVss      | -            | A/D converter ground potential. Connected to Vss.             | -           | -                  |
| RESET     | Input        | System reset input.                                           | -           | -                  |
| X1        | Input        | Main system clock oscillation crystal connection.             | _           | -                  |
| X2        | -            |                                                               | _           | -                  |
| Vdd       | -            | Positive power supply.                                        | _           | -                  |
| Vpp       | -            | High-voltage applied during program write/verification.       | _           | -                  |
|           |              | Connected directly to Vss in normal operating mode.           |             |                    |
| Vss       | -            | Ground potential.                                             | _           | -                  |
| IC        | -            | Internal connection. Connect directly to Vss.                 | -           | -                  |
| NC        | -            | Does not internally connected. Connect to Vss.                | _           | -                  |
|           |              | (It can be left open)                                         |             |                    |

# 2.1.2 PROM programming mode pins (µPD78P083 only)

| Pin Name  | Input/Output | Function                                                                                     |
|-----------|--------------|----------------------------------------------------------------------------------------------|
| RESET     | Input        | PROM programming mode setting.                                                               |
|           |              | When +5 V or +12.5 V is applied to the $V_{PP}$ pin or a low level voltage is applied to the |
|           |              | RESET pin, the PROM programming mode is set.                                                 |
| Vpp       | Input        | High-voltage application for PROM programming mode setting and program write/verify.         |
| A0 to A14 | Input        | Address bus                                                                                  |
| D0 to D7  | Input/output | Data bus                                                                                     |
| CE        | Input        | PROM enable input/program pulse input                                                        |
| ŌĒ        | Input        | Read strobe input to PROM                                                                    |
| PGM       | Input        | Program/program inhibit input in PROM programming mode                                       |
| Vdd       | _            | Positive power supply                                                                        |
| Vss       | _            | Ground potential                                                                             |

# 2.2 Description of Pin Functions

# 2.2.1 P00 to P03 (Port 0)

These are 4-bit input/output ports. Besides serving as input/output ports, they function as an external interrupt request input.

The following operating modes can be specified bit-wise.

# (1) Port mode

P00 functions as input-only port and P01 to P03 function as input/output ports.

P01 to P03 can be specified for input or output ports bit-wise with a port mode register 0 (PM0). When they are used as input ports, on-chip pull-up resistors can be used to them by defining the pull-up resistor option register L (PUOL).

# (2) Control mode

INTP1 to INTP3 function as external interrupt request input pins which are capable of specifying the valid edges (rising edge, falling edge, and both rising and falling edges).

# 2.2.2 P10 to P17 (Port 1)

These are 8-bit input/output ports. Besides serving as input/output ports, they function as an A/D converter analog input.

The following operating modes can be specified bit-wise.

# (1) Port mode

These ports function as 8-bit input/output ports.

They can be specified bit-wise as input or output ports with a port mode register 1 (PM1). If used as input ports, on-chip pull-up resistors can be used to these ports by defining the pull-up resistor option register L (PUOL).

#### (2) Control mode

These ports function as A/D converter analog input pins (ANI0-ANI7). The on-chip pull-up resistor is automatically disabled when the pins specified for analog input.

#### 2.2.3 P30 to P37 (Port 3)

These are 8-bit input/output ports. Beside serving as input/output ports, they function as clock output and buzzer output.

The following operating modes can be specified bit-wise.

#### (1) Port mode

These ports function as 8-bit input/output ports. They can be specified bit-wise as input or output ports with port mode register 3 (PM3). When they are used as input ports, on-chip pull-up resistors can be used by defining the pull-up resistor option register L (PUOL).

#### (2) Control mode

These ports function as clock output, and buzzer output.

(a) PCL

Clock output pin.

#### (b) BUZ

Buzzer output pin.

#### 2.2.4 P50 to P57 (Port 5)

These are 8-bit input/output ports. They can be specified bit-wise as input/output ports with port mode register 5 (PM5). When they are used as input ports, on-chip pull-up resistors can be used by defining the pull-up resistor option register L (PUOL). A maximum of 7 out of 8 ports can drive LEDs directly.

#### 2.2.5 P70 to P72 (Port 7)

This is a 3-bit input/output port. In addition to its use as an input/output port, it also has serial interface data input/ output and clock input/output functions.

The following operating modes can be specified bit-wise.

#### (1) Port mode

Port 7 functions as a 3-bit input/output port. Bit-wise specification as an input port or output port is possible by means of port mode register 7 (PM7). When used as input ports, on-chip pull-up resistors can be used by defining the pull-up resistor option register L (PUOL).

#### (2) Control mode

Port 7 functions as serial interface data input/output and clock input/output.

#### (a) SI2, SO2

Serial interface serial data input/output pins

#### (b) SCK2

Serial interface serial clock input/output pin.

# (c) RxD, TxD

Asynchronous serial interface serial data input/output pins.

#### (d) ASCK

Asynchronous serial interface serial clock input pin.

# Caution When this port is used as a serial interface, the I/O and output latches must be set according to the function the user requires. For the setting, see the operation mode setting list in Table 11-2 "Serial Interface Channel 2 Operating Mode Settings"

# 2.2.6 P100 to P101 (Port 10)

These are 2-bit input/output ports. Besides serving as input/output ports, they function as timer input/output. The following operating modes can be specified bit-wise.

#### (1) Port mode

These ports function as 2-bit input/output ports. They can be specified bit-wise as input or output ports with port mode register 10 (PM10). When they are used as input ports, on-chip pull-up resistors can be used by defining the pull-up resistor option register H (PUOH).

#### (2) Control mode

These ports function as timer input/output.

#### (a) TI5, TI6

Pin for external clock input to the 8-bit timer/event counter 5 and 6.

#### (b) TO5, TO6

Timer output pins.

# 2.2.7 AVREF

A/D converter reference voltage input pin.

When A/D converter is not used, connect this pin to Vss.

# 2.2.8 AVDD

Analog power supply pin of A/D converter. Always use the same voltage as that of the  $V_{DD}$  pin even when A/D converter is not used.

# 2.2.9 AVss

This is a ground voltage pin of A/D converter. Always use the same voltage as that of the Vss pin even when A/ D converter is not used.

#### 2.2.10 RESET

This is a low-level active system reset input pin.

#### 2.2.11 X1 and X2

Crystal resonator connect pins for main system clock oscillation. For external clock supply, input it to X1 and its inverted signal to X2.

#### 2.2.12 VDD

Positive power supply pin

#### 2.2.13 Vss

Ground potential pin

# 2.2.14 VPP (µPD78P083 only)

High-voltage apply pin for PROM programming mode setting and program write/verify. Connect directly to Vss in normal operating mode.

#### 2.2.15 IC (Mask ROM version only)

The IC (Internally Connected) pin is provided to set the test mode to check the  $\mu$ PD78083 Subseries at delivery. Connect it directly to the Vss with the shortest possible wire in the normal operating mode.

When a voltage difference is produced between the IC pin and Vss pin because the wiring between those two pins is too long or an external noise is input to the IC pin, the user's program may not run normally.

# $\odot$ Connect IC pins to Vss pins directly.



#### 2.2.16 NC (44-pin plastic QFP versions only)

Not internally connected. Please connect to Vss (open is also possible)

# 2.3 Pin Input/Output Circuits and Recommended Connection of Unused Pins

Types of input/output circuits of the pins and recommeded connection of unused pins are shown in Table 2-1. For the configuration of each type of input/output circuit, see Figure 2-1.

| Pin Name               | Input/Output | Input/Output | Recommended Connection for Unused Pins       |
|------------------------|--------------|--------------|----------------------------------------------|
|                        | Circuit Type |              |                                              |
| P00                    | 2            | Input        | Connect to Vss.                              |
| P01/INTP1              | 8-A          | Input/Output | Independently connect to Vss via a resistor. |
| P02/INTP2              |              |              |                                              |
| P03/INTP3              |              |              |                                              |
| P10/ANI0-P17/ANI7      | 11           | Input/Output | Independently connect to VDD or Vss via      |
| P30-P32                | 5-A          | 1            | a resistor.                                  |
| P33, P34               | 8-A          | 1            |                                              |
| P35/PCL                | 5-A          | 1            |                                              |
| P36/BUZ                |              |              |                                              |
| P37                    | _            |              |                                              |
| P50-P57                | 5-A          | 1            |                                              |
| P70/SI2/RxD            | 8-A          | ]            |                                              |
| P71/SO2/TxD            | 5-A          | 1            |                                              |
| P72/SCK2/ASCK          | 8-A          | ]            |                                              |
| P100/TI5/TO5           | 8-A          | 1            |                                              |
| P101/TI6/TO6           | -            |              |                                              |
| RESET                  | 2            | Input        | _                                            |
| AVref                  | -            | -            | Connect to Vss.                              |
| AVdd                   |              |              | Connect to VDD.                              |
| AVss                   |              |              | Connect to Vss.                              |
| Vpp (µPD78P083)        | ]            |              | Connect directly to Vss.                     |
| NC (44-pin plastic QFP | 1            |              | Connect to Vss (can also leave open)         |
| version)               |              |              |                                              |
| IC (Mask ROM version)  | 1            |              | Connect directly to Vss.                     |

# Table 2-1. Type of Input/Output Circuit of Each Pin



Figure 2-1. Pin Input/Output Circuit of List

[MEMO]

# CHAPTER 3 CPU ARCHITECTURE

# 3.1 Memory Spaces

Figures 3-1 to 3-3 shows memory maps.







Figure 3-2. Memory Map (µPD78082)





#### 3.1.1 Internal program memory space

The internal program memory is mask ROM with a  $8192 \times 8$ -bit configuration in the  $\mu$ PD78081, and a  $16384 \times 8$ -bit configuration in the  $\mu$ PD78082, and PROM with a  $24576 \times 8$ -bit configuration in the  $\mu$ PD78083.

The internal program memory space stores programs and table data. Normally, they are addressed with a program counter (PC).

The internal program memory is divided into the following three areas.

#### (1) Vector table area

The 64-byte area 0000H to 003FH is reserved as a vector table area. The RESET input and program start addresses for branch upon generation of each interrupt request are stored in the vector table area. Of the 16-bit address, low-order 8 bits are stored at even addresses and high-order 8 bits are stored at odd addresses.

| Vector Table Address | Interrupt Request |
|----------------------|-------------------|
| 0000H                | RESET input       |
| 0004H                | INTWDT            |
| 0008H                | INTP1             |
| 000AH                | INTP2             |
| 000CH                | INTP3             |
| 0018H                | INTSER            |
| 001AH                | INTSR/INTCSI2     |
| 001CH                | INTST             |
| 0028H                | INTAD             |
| 002AH                | INTTM5            |
| 002CH                | INTTM6            |
| 003EH                | BRK               |
|                      |                   |

Table 3-1. Vector Table

# (2) CALLT instruction table area

The 64-byte area 0040H to 007FH can store the subroutine entry address of a 1-byte call instruction (CALLT).

# (3) CALLF instruction entry area

The area 0800H to 0FFFH can perform a direct subroutine call with a 2-byte call instruction (CALLF).

#### 3.1.2 Internal data memory space

The internal high speed RAM configuration is  $256 \times 8$ -bit in the  $\mu$ PD78081,  $384 \times 8$ -bit in the  $\mu$ PD78082 and 512  $\times$  8-bit in the  $\mu$ PD8P083. In this area, four banks of general registers, each bank consisting of eight 8-bit registers, are allocated in the 32-byte area FEE0H to FEFFH.

The internal high-speed RAM can also be used as a stack memory area.

#### 3.1.3 Special Function Register (SFR) area

An on-chip peripheral hardware special-function register (SFR) is allocated in the area FF00H to FFFFH. (Refer to Table 3-2. Special-Function Register List in 3.2.3 Special Function Register (SFR)).

#### Caution Do not access addresses where the SFR is not assigned.

#### 3.1.4 Data memory addressing

The method to specify the address of the instruction to be executed next, or the address of a register or memory to be manipulated when an instruction is executed is called addressing.

The address of the instruction to be executed next is addressed by the program counter PC (for details, refer to **3.3 Instruction Address Addressing**).

To address the memory that is manipulated when an instruction is executed, the  $\mu$ PD78083 Subseries is provided with many addressing modes with a high operability. Especially at addresses corresponding to data memory area, particular addressing modes are possible to meet the functions of the special function registers (SFRs) and general registers. This area is between FE00H and FFFFH for the  $\mu$ PD78081, FD80H and FFFFH for the  $\mu$ PD78082, and between FD00H and FFFFH for the  $\mu$ PD78P083. The data memory space is the entire 64K-byte space (0000H to FFFFH). Figure 3-4 to 3-6 show the data memory addressing modes. For details of each addressing, refer to **3.4 Operand Address Addressing**.



Figure 3-4. Data Memory Addressing (µPD78081)



Figure 3-5. Data Memory Addressing (µPD78082)



Figure 3-6. Data Memory Addressing (µPD78P083)

#### 3.2 Processor Registers

The  $\mu$ PD78083 subseries units incorporate the following processor registers.

#### 3.2.1 Control registers

The control registers control the program sequence, statuses and stack memory. The control registers consist of a program counter, a program status word and a stack pointer.

#### (1) Program counter (PC)

The program counter is a 16-bit register which holds the address information of the next program to be executed.

In normal operation, the PC is automatically incremented according to the number of bytes of the instruction to be fetched. When a branch instruction is executed, immediate data and register contents are set.

RESET input sets the reset vector table values at addresses 0000H and 0001H to the program counter.





#### (2) Program status word (PSW)

The program status word is an 8-bit register consisting of various flags to be set/reset by instruction execution. Program status word contents are automatically stacked upon interrupt request generation or PUSH PSW instruction execution and are automatically reset upon execution of the RETB, RETI and POP PSW instructions. RESET input sets the PSW to 02H.

#### Figure 3-8. Program Status Word Configuration

| 7  |   |      |    |      |   |     | 0  |
|----|---|------|----|------|---|-----|----|
| IE | Z | RBS1 | AC | RBS0 | 0 | ISP | CY |

#### (a) Interrupt enable flag (IE)

This flag controls the interrupt request acknowledge operations of the CPU.

When IE = 0, all interrupts except the non-maskable interrupt are disabled (DI status).

When IE = 1, interrupts are enabled (EI status). At this time, acknowledgment of interrupts is controlled with an inservice priority flag (ISP), an interrupt mask flag for various interrupt sources, and a priority specify flag.

The interrupt enable flag is reset to 0 when the DI instruction is executed or when an interrupt request is acknowledged, and set to 1 when the EI instruction is executed.

# (b) Zero flag (Z)

When the operation result is zero, this flag is set (1). It is reset (0) in all other cases.

#### (c) Register bank select flags (RBS0 and RBS1)

These are 2-bit flags to select one of the four register banks. In these flags, the 2-bit information which indicates the register bank selected by SEL RBn instruction execution is stored.

# (d) Auxiliary carry flag (AC)

If the operation result has a carry from bit 3 or a borrow at bit 3, this flag is set (1). It is reset (0) in all other cases.

# (e) In-service priority flag (ISP)

This flag manages the priority of acknowledgeable maskable vectored interrupts. When ISP = 0, the vectored interrupt request whose priority is specified by the priority specify flag registers (PR0L, PR0H, and PR1L) (Refer to **12.3 (3) Priority specify flag registers (PR0L, PR0H, and PR1L)**) to be low is disabled. Whether the interrupt request is actually acknowledged is controlled by the status of the interrupt enable flag (IE).

# (f) Carry flag (CY)

This flag stores overflow and underflow upon add/subtract instruction execution. It stores the shift-out value upon rotate instruction execution and functions as a bit accumulator during bit manipulation instruction execution.

#### (3) Stack pointer (SP)

This is a 16-bit register to hold the start address of the memory stack area. Only the internal high-speed RAM area (FE00H-FEFFH for the  $\mu$ PD78081, FD80H-FEFFH for the  $\mu$ PD78082, and FD00H-FEFFH for the  $\mu$ PD78P083) can be set as the stack area.





The SP is decremented ahead of write (save) to the stack memory and is incremented after read (reset) from the stack memory.

Each stack operation saves/resets data as shown in Figures 3-10 and 3-11.

# Caution Since $\overline{\text{RESET}}$ input makes SP contents indeterminate, be sure to initialize the SP before instruction execution.



#### Figure 3-10. Data to be Saved to Stack Memory

Figure 3-11. Data to be Reset from Stack Memory



#### 3.2.2 General registers

A general register is mapped at particular addresses (FEE0H to FEFFH) of the data memory. It consists of 4 banks, each bank consisting of eight 8-bit registers (X, A, C, B, E, D, L and H).

Each register can also be used as an 8-bit register. Two 8-bit registers can be used in pairs as a 16-bit register (AX, BC, DE and HL).

They can be described in terms of function names (X, A, C, B, E, D, L, H, AX, BC, DE and HL) and absolute names (R0 to R7 and RP0 to RP3).

Register banks to be used for instruction execution are set with the CPU control instruction (SEL RBn). Because of the 4-register bank configuration, an efficient program can be created by switching between a register for normal processing and a register for interruption request for each bank.

#### Figure 3-12. General Register Configuration



#### (a) Absolute Name

#### (b) Function Name



#### 3.2.3 Special Function Register (SFR)

Unlike a general register, each special-function register has special functions.

It is allocated in the FF00H to FFFFH area.

The special-function register can be manipulated like the general register, with the operation, transfer and bit manipulation instructions. Manipulatable bit units, 1, 8 and 16, depend on the special-function register type.

Each manipulation bit unit can be specified as follows.

• 1-bit manipulation

Describe the symbol reserved with assembler for the 1-bit manipulation instruction operand (sfr.bit). This manipulation can also be specified with an address.

• 8-bit manipulation

Describe the symbol reserved with assembler for the 8-bit manipulation instruction operand (sfr). This manipulation can also be specified with an address.

• 16-bit manipulation

Describe the symbol reserved with assembler for the 16-bit manipulation instruction operand (sfrp). When addressing an address, describe an even address.

Table 3-2 gives a list of special-function registers. The meaning of items in the table is as follows.

Symbol

÷

- Symbols indicating the addresses of special function register. These symbols are reserved words for the RA78K/ 0 and defined by header file sfrbit.h for the CC78K/0, and can be used as the operands of instructions when the RA78K/0, ID78K0, and SD78K/0 are used.
- R/W

Indicates whether the corresponding special-function register can be read or written.

- R/W : Read/write enable
- R : Read only
- W : Write only
- · Manipulatable bit units

 $\sqrt{}$  indicates bit units (1, 8 or 16 bits) in which the register can be manipulated. — indicates that the register cannot be manipulated in the indicated bit units.

• After reset

Indicates each register status upon RESET input.

|         |                                               |      |      |     | Manip        | oulatable E  | Bit Unit     |             |
|---------|-----------------------------------------------|------|------|-----|--------------|--------------|--------------|-------------|
| Address | Special-Function Register (SFR) Name          | Sym  | nbol | R/W | 1 bit        | 8 bits       | 16 bits      | After Reset |
| FF00H   | Port0                                         | F    | P0   |     | $\checkmark$ |              | _            | 00H         |
| FF01H   | Port1                                         | F    | P1   |     |              |              | _            |             |
| FF03H   | Port3                                         | F    | °3   |     | $\checkmark$ | $\checkmark$ | _            |             |
| FF05H   | Port5                                         | F    | °5   |     | √            |              | _            |             |
| FF07H   | Port7                                         | F    | 7    |     | $\checkmark$ |              |              |             |
| FF0AH   | Port10                                        | Р    | 10   |     | $\checkmark$ | $\checkmark$ |              |             |
| FF1FH   | A/D conversion result register                | AD   | CR   | R   | $\checkmark$ |              | _            | Undefined   |
| FF20H   | Port mode register 0                          | PI   | M0   | R/W | $\checkmark$ |              | _            | FFH         |
| FF21H   | Port mode register 1                          | PI   | VI1  |     | $\checkmark$ | $\checkmark$ |              |             |
| FF23H   | Port mode register 3                          | PI   | ИЗ   |     | $\checkmark$ |              | _            |             |
| FF25H   | Port mode register 5                          | PI   | M5   |     | $\checkmark$ | $\checkmark$ | _            |             |
| FF27H   | Port mode register 7                          | PI   | M7   |     | $\checkmark$ |              | _            |             |
| FF2AH   | Port mode register 10                         | PN   | /10  |     | $\checkmark$ |              | _            |             |
| FF40H   | Timer clock select register 0                 | тс   | CL0  |     | $\checkmark$ |              | _            | 00H         |
| FF42H   | Timer clock select register 2                 | тс   | L2   |     | _            |              | _            |             |
| FF50H   | Compare Register 50                           | CF   | R50  |     | _            | $\checkmark$ | _            |             |
| FF51H   | 8-bit timer register 5                        | TM5  |      | R   | _            |              | _            |             |
| FF52H   | Timer clock select register 5                 | тс   | TCL5 |     | _            |              | _            |             |
| FF53H   | 8-bit timer mode control register 5           | T№   | 1C5  |     | $\checkmark$ |              | _            |             |
| FF54H   | Compare Register 60                           | CF   | R60  |     | _            | $\checkmark$ | _            |             |
| FF55H   | 8-bit timer register 6                        | т    | M6   | R   | _            | $\checkmark$ | _            |             |
| FF56H   | Timer clock select register 6                 | тс   | CL6  | R/W | _            |              | _            |             |
| FF57H   | 8-bit timer mode control register 6           | TΝ   | 1C6  |     | $\checkmark$ | $\checkmark$ | _            |             |
| FF70H   | Asynchronous serial interface mode register   | AS   | SIM  |     | $\checkmark$ | $\checkmark$ |              |             |
| FF71H   | Asynchronous serial interface status register | AS   | SIS  | R   | $\checkmark$ | $\checkmark$ |              |             |
| FF72H   | Serial operating mode register 2              | CS   | IM2  | R/W | $\checkmark$ | $\checkmark$ | —            |             |
| FF73H   | Baud rate generator control register          | BR   | GC   |     | —            | $\checkmark$ | —            |             |
| FF74H   | Transmit shift register                       | TXS  | SIO2 | W   |              | $\checkmark$ | _            | FFH         |
|         | Receive buffer register                       | RXB  |      | R   |              |              |              |             |
| FF80H   | A/D converter mode register                   | A    | DM   | R/W | $\checkmark$ | $\checkmark$ | —            | 01H         |
| FF84H   | A/D converter input select register           | ADIS |      |     | _            | $\checkmark$ | —            | 00H         |
| FFE0H   | Interrupt request flag register 0L            | IF0  | IF0L |     | $\checkmark$ | $\checkmark$ | $\checkmark$ |             |
| FFE1H   | Interrupt request flag register 0H            |      | IF0H |     | $\checkmark$ | $\checkmark$ |              |             |
| FFE2H   | Interrupt request flag register 1L            | IF   | 1L   |     | $\checkmark$ | $\checkmark$ | —            |             |
| FFE4H   | Interrupt mask flag register 0L               | МКО  | MK0L |     | $\checkmark$ |              | √            | FFH         |
| FFE5H   | Interrupt mask flag register 0H               |      | мкон |     | √            |              |              |             |
| FFE6H   | Interrupt mask flag register 1L               | Mł   | <1L  |     | √            |              |              |             |
| FFE8H   | Priority order specify flag register 0L       | PR0  | PR0L |     | √            |              | $\checkmark$ |             |
| FFE9H   | Priority order specify flag register 0H       |      | PR0H |     | $\checkmark$ |              |              |             |

| Table 3-2. | <b>Special-Function</b> | Register List | (1/2) |
|------------|-------------------------|---------------|-------|
|            | opeoiar i anotion       | Regiotor Liot | ("~)  |

| Addross | Special Europian Register (SER) Name           | Symbol | DAA | Manip        |              |         |             |
|---------|------------------------------------------------|--------|-----|--------------|--------------|---------|-------------|
| Address | Address Special-Function Register (SFR) Name   |        | R/W | 1 bit        | 8 bits       | 16 bits | After Reset |
| FFEAH   | Priority order specify flag register 1L        | PR1L   | R/W | $\checkmark$ | $\checkmark$ | _       | FFH         |
| FFECH   | External interrupt mode register 0             | INTM0  | ]   | _            | $\checkmark$ | _       | 00H         |
| FFEDH   | External interrupt mode register 1             | INTM1  |     | _            | V            | _       |             |
| FFF0H   | Memory size switching register                 | IMS    |     | _            | $\checkmark$ | _       | (Note)      |
| FFF2H   | Oscillation mode selection register            | OSMS   | W   | _            | $\checkmark$ | _       | 00H         |
| FFF3H   | Pull-up resistor option register H             | PUOH   | R/W | $\checkmark$ | $\checkmark$ | _       |             |
| FFF7H   | Pull-up resistor option register L             | PUOL   |     | $\checkmark$ | $\checkmark$ | _       |             |
| FFF9H   | Watchdog timer mode register                   | WDTM   |     | $\checkmark$ | $\checkmark$ | _       |             |
| FFFAH   | Oscillation stabilization time select register | OSTS   |     | _            | V            | _       | 04H         |
| FFFBH   | Processor clock control register               | PCC    | ]   | $\checkmark$ | V            | _       |             |

Table 3-2. Special-Function Register List (2/2)

**Note** The value after reset depends on products.

 $\mu \text{PD78081}: \text{82H}, \ \mu \text{PD78082}: \text{64H}, \ \mu \text{PD78P083}: \text{46H}.$ 

★

#### 3.3 Instruction Address Addressing

An instruction address is determined by program counter (PC) contents. The contents of PC are normally incremented (+1 for each byte) automatically according to the number of bytes of an instruction to be fetched each time another instruction is executed. When a branch instruction is executed, the branch destination information is set to the PC and branched by the following addressing. (For details of instructions, refer to **78K/0 USER'S MANUAL: Instruction (IEU-1372)**.

#### 3.3.1 Relative addressing

#### [Function]

The value obtained by adding 8-bit immediate data (displacement value: jdisp8) of an instruction code to the start address of the following instruction is transferred to the program counter (PC) and branched. The displacement value is treated as signed two's complement data (-128 to +127) and bit 7 becomes a sign bit. In the relative addressing modes, execution branches in a relative range of -128 to +127 from the first address of the next instruction.

This function is carried out when the BR \$addr16 instruction or a conditional branch instruction is executed.

#### [Illustration]



When S = 0, all bits of  $\alpha$  are 0. When S = 1, all bits of  $\alpha$  are 1.

#### 3.3.2 Immediate addressing

#### [Function]

Immediate data in the instruction word is transferred to the program counter (PC) and branched. This function is carried out when the CALL !addr16 or BR !addr16 or CALLF !addr11 instruction is executed. The CALL !addr16 and BR !addr16 instruction can branch in the entire memory space. The CALLF !addr11 instruction branches to an area of addresses 0800H through 0FFFH.

# [Illustration]

In the case of CALL !addr16 and BR !addr16 instructions



In the case of CALLF !addr11 instruction



#### 3.3.3 Table indirect addressing

# [Function]

Table contents (branch destination address) of the particular location to be addressed by bits 1 to 5 of the immediate data of an operation code are transferred to the program counter (PC) and branched.

Before the CALLT [addr5] instruction is executed, table indirect addressing is performed. This instruction references an address stored in the memory table at addresses 40H through 7FH, and can branch in the entire memory space.

# [Illustration]



# 3.3.4 Register addressing

# [Function]

Register pair (AX) contents to be specified with an instruction word are transferred to the program counter (PC) and branched.

This function is carried out when the BR AX instruction is executed.

# [Illustration]



# 3.4 Operand Address Addressing

The following various methods are available to specify the register and memory (addressing) which undergo manipulation during instruction execution.

#### 3.4.1 Implied addressing

#### [Function]

The register which functions as an accumulator (A and AX) in the general register is automatically (illicitly) addressed.

Of the µPD78083 Subseries instruction words, the following instructions employ implied addressing.

| Instruction | Register to be Specified by Implied Addressing                                   |
|-------------|----------------------------------------------------------------------------------|
| MULU        | A register for multiplicand and AX register for product storage                  |
| DIVUW       | AX register for dividend and quotient storage                                    |
| ADJBA/ADJBS | A register for storage of numeric values which become decimal correction targets |
| ROR4/ROL4   | A register for storage of digit data which undergoes digit rotation              |

# [Operand format]

Because implied addressing can be automatically employed with an instruction, no particular operand format is necessary.

#### [Description example]

In the case of MULU X

With an 8-bit  $\times$  8-bit multiply instruction, the product of A register and X register is stored in AX. In this example, the A and AX registers are specified by implied addressing.

#### 3.4.2 Register addressing

#### [Function]

This addressing accesses a general register as an operand. The general register accessed is specified by the register bank select flags (RBS0 and RBS1) and register specify code (Rn or RPn) in an instruction code. Register addressing is carried out when an instruction with the following operand format is executed. When an 8-bit register is specified, one of the eight registers is specified with 3 bits in the operation code.

#### [Operand format]

| Identifier | Description            |
|------------|------------------------|
| r          | X, A, C, B, E, D, L, H |
| rp         | AX, BC, DE, HL         |

'r' and 'rp' can be described with function names (X, A, C, B, E, D, L, H, AX, BC, DE and HL) as well as absolute names (R0 to R7 and RP0 to RP3).

#### [Description example]

MOV A, C; when selecting C register as r



INCW DE; when selecting DE register pair as rp

Operation code



# 3.4.3 Direct addressing

# [Function]

This addressing directly addresses the memory indicated by the immediate data in an instruction word.

#### [Operand format]

| Identifier | Description                    |
|------------|--------------------------------|
| addr16     | Label or 16-bit immediate data |

# [Description example]

MOV A, !0FE00H; when setting !addr16 to FE00H



# [Illustration]



#### 3.4.4 Short direct addressing

#### [Function]

The memory to be manipulated in the fixed space is directly addressed with 8-bit data in an instruction word. The fixed space to which this address is applied is a 256-byte space of addresses FE20H through FF1FH. An internal high-speed RAM and a special-function register (SFR) are mapped at FE20H to FEFFH and FF00H to FF1FH, respectively.

The SFR area (FF00H through FF1FH) to which short direct addressing is applied is a part of the entire SFR area. To this area, ports frequently accessed by the program, and the compare registers and capture registers of timer/event counters are mapped. These SFRs can be manipulated with a short byte length and a few clocks. When 8-bit immediate data is at 20H to FFH, bit 8 of an effective address is set to 0. When it is at 00H to 1FH, bit 8 is set to 1. Refer to **[Illustration]** on next page.

# [Operand format]

| Identifier | Description                                                |  |  |  |  |  |  |  |
|------------|------------------------------------------------------------|--|--|--|--|--|--|--|
| saddr      | Label of FE20H to FF1FH immediate data                     |  |  |  |  |  |  |  |
| saddrp     | Label of FE20H to FF1FH immediate data (even address only) |  |  |  |  |  |  |  |

# [Description example]

MOV 0FE30H, #50H; when setting saddr to FE30H and immediate data to 50H



When 8-bit immediate data is 20H to FFH,  $\alpha$  = 0 When 8-bit immediate data is 00H to 1FH,  $\alpha$  = 1

# 3.4.5 Special-Function Register (SFR) addressing

# [Function]

The memory-mapped special-function register (SFR) is addressed with 8-bit immediate data in an instruction word.

This addressing is applied to the 240-byte spaces FF00H to FFCFH and FFE0H to FFFFH. However, the SFR mapped at FF00H to FF1FH can be accessed with short direct addressing.

# [Operand format]

| Identifier | Description                                                             |  |  |  |  |  |  |
|------------|-------------------------------------------------------------------------|--|--|--|--|--|--|
| sfr        | Special-function register name                                          |  |  |  |  |  |  |
| sfrp       | 16-bit manipulatable special-function register name (even address only) |  |  |  |  |  |  |

# [Description example]

| MOV PM0, A; when selecting PM0 (FF20H) as sfr |                |   |   |   |   |   |   |   |   |                  |  |
|-----------------------------------------------|----------------|---|---|---|---|---|---|---|---|------------------|--|
|                                               | Operation code | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | OP code          |  |
|                                               |                | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 20H (sfr-offset) |  |
| [Illustration]                                |                |   |   |   |   |   |   |   |   |                  |  |

#### [Illustrat ן ו



## 3.4.6 Register indirect addressing

# [Function]

This addressing addresses the memory with the contents of a register pair specified as an operand. The register pair to be accessed is specified by the register bank select flags (RBS0 and RBS1) and register pair specify code in an instruction code. This addressing can be carried out for all the memory spaces.

## [Operand format]

| Identifier | Description |
|------------|-------------|
| _          | [DE], [HL]  |

# [Description example]

MOV A, [DE]; when selecting [DE] as register pair

Operation code

1 0

# [Illustration]



## 3.4.7 Based addressing

#### [Function]

This addressing addresses the memory by adding 8-bit immediate data to the contents of the HL register pair which is used as a base register and by using the result of the addition. The HL register pair to be accessed is in the register bank specified by the register bank select flags (RBS0 and RBS1). Addition is performed by expanding the offset data as a positive number to 16 bits. A carry from the 16th bit is ignored. This addressing can be carried out for all the memory spaces.

# [Operand format]

| Identifier | Description |
|------------|-------------|
| —          | [HL + byte] |

## [Description example]

MOV A, [HL + 10H]; when setting byte to 10H

Operation code

## 3.4.8 Based indexed addressing

## [Function]

This addressing addresses the memory by adding the contents of the HL register, which is used as a base register, to the contents of the B or C register specified in the instruction word, and by using the result of the addition. The HL, B, and C registers to be accessed are registers in the register bank specified by the register bank select flags (RBS0 and RBS1). The addition is performed by extending the contents of the B or C register to 16 bits as a positive number. A carry from the 16th bit is ignored. This addressing can be carried out for all the memory spaces.

[Operand format]

| Identifier | Description        |  |
|------------|--------------------|--|
| _          | [HL + B], [HL + C] |  |

[Description example]

In the case of MOV A, [HL + B]

Operation code

## 3.4.9 Stack addressing

## [Function]

The stack area is indirectly addressed with the stack pointer (SP) contents.

This addressing method is automatically employed when the PUSH, POP, subroutine call and RETURN instructions are executed or the register is saved/reset upon generation of an interrupt request. Stack addressing enables to address the internal high-speed RAM area only.

[Description example]

In the case of PUSH DE

Operation code

1 0 1 1 0 1 0 1

# **CHAPTER 4 PORT FUNCTIONS**

# 4.1 Port Functions

The  $\mu$ PD78083 Subseries units incorporate an input port and thirty-two input/output ports. Figure 4-1 shows the port configuration. Every port is capable of 1-bit and 8-bit manipulations and can carry out considerably varied control operations. Besides port functions, the ports can also serve as on-chip hardware input/output pins.



Figure 4-1. Port Types

| Pin Name | Input/Output                          |                                                                    | Function                                              | Dual-Function Pin |  |
|----------|---------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------|-------------------|--|
| P00      | Input                                 | Port 0                                                             | Input only                                            | —                 |  |
| P01      | Input/output                          | 4-bit input/output port Input/output is specifiable bit-wise. When |                                                       | INTP1             |  |
| P02      | 7                                     |                                                                    | used as the input port, it is possible to connect     |                   |  |
| P03      | 1                                     |                                                                    | a pull-up resistor by software.                       | INTP3             |  |
| P10-P17  | Input/output                          | Port 1                                                             |                                                       | ANI0-ANI7         |  |
|          |                                       | 8-bit input/output port                                            |                                                       |                   |  |
|          |                                       | Input/output is specifial                                          | ble bit-wise.                                         |                   |  |
|          |                                       | When used as the inp                                               | ut port, it is possible to connect a pull-up resistor |                   |  |
|          |                                       | by software.                                                       |                                                       |                   |  |
| P30-P34  | Input/output                          | Port 3                                                             |                                                       | —                 |  |
| P35      |                                       | 8-bit input/output port                                            |                                                       | PCL               |  |
| P36      |                                       | Input/output is specifial                                          | ble bit-wise.                                         | BUZ               |  |
| P37      |                                       | When used as the inp                                               | ut port, it is possible to connect a pull-up resistor | —                 |  |
|          | by software.                          |                                                                    |                                                       |                   |  |
| P50-P57  | P50-P57 Input/output Port 5           |                                                                    |                                                       |                   |  |
|          |                                       | 8-bit input/output port                                            |                                                       |                   |  |
|          |                                       | A maximum of 7 out of                                              | 8 ports can drive LEDs directly.                      |                   |  |
|          |                                       | Input/output is specifial                                          | ble bit-wise.                                         |                   |  |
|          |                                       | When used as the inp                                               | ut port, it is possible to connect a pull-up resistor |                   |  |
|          |                                       | by software.                                                       |                                                       |                   |  |
| P70      | Input/output                          | Port 7                                                             |                                                       | SI2/RxD           |  |
| P71      | 7                                     | 3-bit input/output port                                            |                                                       | SO2/TxD           |  |
| P72      | 7                                     | Input/output is specifial                                          | SCK2/ASCK                                             |                   |  |
|          |                                       | When used as the inp                                               | ut port, it is possible to connect a pull-up resistor |                   |  |
|          | by software.                          |                                                                    |                                                       |                   |  |
| P100     | Input/output                          | Port 10                                                            | TI5/TO5                                               |                   |  |
| P101     | 2-bit input/output port               |                                                                    |                                                       |                   |  |
|          | Input/output is specifiable bit-wise. |                                                                    |                                                       |                   |  |
|          |                                       | When used as the inp                                               |                                                       |                   |  |
|          | by software.                          |                                                                    |                                                       |                   |  |

# Table 4-1. Port Functions

# 4.2 Port Configuration

A port consists of the following hardware:

| Item             | Configuration                                   |  |  |
|------------------|-------------------------------------------------|--|--|
| Control register | Port mode register (PMm: m = 0, 1, 3, 5, 7, 10) |  |  |
|                  | Pull-up resistor option register (PUOH, PUOL)   |  |  |
| Port             | Total: 33 ports (1 input, 32 inputs/outputs)    |  |  |
| Pull-up resistor | Total: 32 (software specifiable)                |  |  |

| Table | 4-2.       | Port  | Configuration |
|-------|------------|-------|---------------|
| IUDIC | <b>T A</b> | 1 011 | oomiguration  |

#### 4.2.1 Port 0

Port 0 is an 4-bit input/output port with output latch. P01 to P03 pins can specify the input mode/output mode in 1-bit units with the port mode register 0 (PM0). P00 pin is input-only port. When P01 to P03 pins are used as input ports, an on-chip pull-up resistor can be used to them in 3-bit units with a pull-up resistor option register L (PUOL).

Dual-functions include external interrupt request input.

RESET input sets port 0 to input mode.

Figures 4-2 and 4-3 show block diagrams of port0.

Caution Because port 0 also serves for external interrupt request input, when the port function output mode is specified and the output level is changed, the interrupt request flag is set. Thus, when the output mode is used, set the interrupt mask flag to 1.

Figure 4-2. P00 Block Diagram



Figure 4-3. P01 to P03 Block Diagram



- PUO: Pull-up resistor option register
- PM : Port mode register
- RD : Port 0 read signal
- WR : Port 0 write signal

# 4.2.2 Port 1

Port 1 is an 8-bit input/output port with output latch. It can specify the input mode/output mode in 1-bit units with a port mode register 1 (PM1). When P10 to P17 pins are used as input ports, an on-chip pull-up resistor can be used to them in 8-bit units with a pull-up resistor option register L (PUOL).

Dual-functions include an A/D converter analog input.

RESET input sets port 1 to input mode.

Figure 4-4 shows a block diagram of port 1.

## Caution A pull-up resistor cannot be used for pins used as A/D converter analog input.



Figure 4-4. P10 to P17 Block Diagram

- PUO: Pull-up resistor option register
- PM : Port mode register
- RD : Port 1 read signal
- WR : Port 1 write signal

# 4.2.3 Port 3

Port 3 is an 8-bit input/output port with output latch. P30 to P37 pins can specify the input mode/output mode in 1-bit units with the port mode register 3 (PM3). When P30 to P37 pins are used as input ports, an on-chip pull-up resistor can be used to them in 8-bit units with a pull-up resistor option register L (PUOL).

Dual-functions include clock output and buzzer output.

RESET input sets port 3 to input mode.

Figure 4-5 shows a block diagram of port 3.





- PUO: Pull-up resistor option register
- PM : Port mode register
- RD : Port 3 read signal
- WR : Port 3 write signal

## 4.2.4 Port 5

Port 5 is an 8-bit input/output port with output latch. P50 to P57 pins can specify the input mode/output mode in 1-bit units with the port mode register 5 (PM5). When P50 to P57 pins are used as input ports, an on-chip pull-up resistor can be used to them in 8-bit units with a pull-up resistor option register L (PUOL).

A maximum of 7 out of 8 ports can drive LEDs directly.

RESET input sets port 5 to input mode.

Figure 4-6 shows a block diagram of port 5.





PUO: Pull-up resistor option register

PM : Port mode register

RD : Port 5 read signal

WR : Port 5 write signal

# 4.2.5 Port 7

This is a 3-bit input/output port with output latches. Input mode/output mode can be specified bit-wise by means of port mode register 7 (PM7). When pins P70 to P72 are used as input port pins, an on-chip pull-up resistor can be used as a 3-bit unit by means of pull-up resistor option register L (PUOL).

Dual-functions include serial interface channel 2 data input/output and clock input/output.

RESET input sets the input mode.

Port 7 block diagrams are shown in Figures 4-7 and 4-8.

# Caution When used as a serial interface, set the input/output and output latch according to its functions. For the setting method, refer to Table 11-2 Serial Interface Channel 2 Operating Mode Settings.





PUO: Pull-up resistor option register

PM : Port mode register

- RD : Port 7 read signal
- WR : Port 7 write signal

Figure 4-8. P71 and P72 Block Diagram



- PUO: Pull-up resistor option register
- PM : Port mode register
- RD : Port 7 read signal
- WR : Port 7 write signal

# 4.2.6 Port 10

This is an 2-bit input/output port with output latches. Input mode/output mode can be specified bit-wise by means of port mode register 10 (PM10). When pins P100 to P101 are used as input port pins, an on-chip pull-up resistor can be used as an 2-bit unit by means of pull-up resistor option register H (PUOH).

These pins are dual function pins and serve as timer inputs/outputs.

RESET input sets the input mode.

The port 10 block diagram is shown in Figure 4-9.





- PUO: Pull-up resistor option register
- PM : Port mode register
- RD : Port 10 read signal
- WR : Port 10 write signal

# 4.3 Port Function Control Registers

The following two types of registers control the ports.

- Port mode registers (PM0, PM1, PM3, PM5, PM7, PM10)
- Pull-up resistor option register (PUOH, PUOL)

# (1) Port mode registers (PM0, PM1, PM3, PM5, PM7, PM10)

These registers are used to set port input/output in 1-bit units.

PM0, PM1, PM3, PM5, PM7, PM10 are independently set with a 1-bit or 8-bit memory manipulation instruction RESET input sets registers to FFH.

When port pins are used as the dual-function pins, set the port mode register and output latch according to Table 4-3.

# Cautions 1. P00 pin is input-only pin.

 As port 0 has a dual function as external interrupt request input, when the port function output mode is specified and the output level is changed, the interrupt request flag is set. When the output mode is used, therefore, the interrupt mask flag should be set to 1 beforehand.

| Pin Name                   | Dual-functio   | ons          | PM×× | P×× |
|----------------------------|----------------|--------------|------|-----|
|                            | Name           | Input/Output |      |     |
| P01 to P03                 | INTP1 to INTP3 |              | 1    | ×   |
| P10 to P17 <sup>Note</sup> | ANI0 to ANI7   | Input        | 1    | ×   |
| P35                        | PCL            | Output       | 0    | 0   |
| P36                        | BUZ            | Output       | 0    | 0   |
| P100                       | TI5            | Input        | 1    | ×   |
|                            | TO5            | Output       | 0    | 0   |
| P101                       | TI6            | Input        | 1    | ×   |
|                            | TO6            | Output       | 0    | 0   |

# Table 4-3. Port Mode Register and Output Latch Settings when Using Dual-Functions

- **Note** If a read instruction is performed to these pins when they are used as an alternate function, read data is to be undefined.
- Caution When port 7 is used for serial interface, the I/O latch or output latch must be set according to its function. For the setting methods, see Table 11-2 "Serial Interface Channel 2 Operating Mode Settings."
- Remarks  $\times$  : don't care

PM××: port mode register

Pxx : port output latch



Figure 4-10. Port Mode Register Format

Caution Set 1 to the bits 0, 4 to 7 of PM0, bits 3 to 7 of PM7 and bits 2 to 7 of PM10.

## (2) Pull-up resistor option register (PUOH, PUOL)

This register is used to set whether to use an internal pull-up resistor at each port or not. A pull-up resistor is internally used at bits which are set to the input mode at a port where on-chip pull-up resistor use has been specified with PUOH, PUOL. No on-chip pull-up resistors can be used to the bits set to the output mode or to the bits used as an analog input pin, irrespective of PUOH or PUOL setting.

PUOH and PUOL are set with a 1-bit or 8-bit memory manipulation instruction.

RESET input sets this register to 00H.

# Cautions 1. P00 pin does not incorporate a pull-up resistor.

2. When port 1 is used as dual-function pin, an on-chip pull-up resistor cannot be used even if 1 is set in PUOL bit 1 (PUO1).



## Figure 4-11. Pull-Up Resistor Option Register Format

Caution Set 0 to the bits 0, 1, 3 to 7 of PUOH and bits 2, 4, 6 of PUOL.

# 4.4 Port Function Operations

Port operations differ depending on whether the input or output mode is set, as shown below.

## 4.4.1 Writing to input/output port

#### (1) Output mode

A value is written to the output latch by a transfer instruction, and the output latch contents are output from the pin.

Once data is written to the output latch, it is retained until data is written to the output latch again.

#### (2) Input mode

A value is written to the output latch by a transfer instruction, but since the output buffer is OFF, the pin status does not change.

Once data is written to the output latch, it is retained until data is written to the output latch again.

# Caution In the case of 1-bit memory manipulation instruction, although a single bit is manipulated the port is accessed as an 8-bit unit. Therefore, on a port with a mixture of input and output pins, the output latch contents for pins specified as input are undefined except for the manipulated bit.

#### 4.4.2 Reading from input/output port

### (1) Output mode

The output latch contents are read by a transfer instruction. The output latch contents do not change.

#### (2) Input mode

The pin status is read by a transfer instruction. The output latch contents do not change.

#### 4.4.3 Operations on input/output port

#### (1) Output mode

An operation is performed on the output latch contents, and the result is written to the output latch. The output latch contents are output from the pins.

Once data is written to the output latch, it is retained until data is written to the output latch again.

#### (2) Input mode

The output latch contents are undefined, but since the output buffer is OFF, the pin status does not change.

Caution In the case of 1-bit memory manipulation instruction, although a single bit is manipulated the port is accessed as an 8-bit unit. Therefore, on a port with a mixture of input and output pins, the output latch contents for pins specified as input are undefined, even for bits other than the manipulated bit. [MEMO]

# CHAPTER 5 CLOCK GENERATOR

# 5.1 Clock Generator Functions

The clock generator generates the clock to be supplied to the CPU and peripheral hardware. The following type of system clock oscillator is available.

## Main system clock oscillator

This circuit oscillates at frequencies of 1 to 5.0 MHz. Oscillation can be stopped by executing the STOP instruction.

# 5.2 Clock Generator Configuration

The clock generator consists of the following hardware.

| Item             | Configuration                              |  |
|------------------|--------------------------------------------|--|
| Control register | Processor clock control register (PCC)     |  |
|                  | Oscillation mode selection register (OSMS) |  |
| Oscillator       | Main system clock oscillator               |  |

## Table 5-1. Clock Generator Configuration



Figure 5-1. Block Diagram of Clock Generator

# 5.3 Clock Generator Control Register

The clock generator is controlled by the following two registers:

- Processor clock control register (PCC)
- Oscillation mode selection register (OSMS)

# (1) Processor clock control register (PCC)

The PCC sets whether to use CPU clock selection and the ratio of division. The PCC is set with a 1-bit or 8-bit memory manipulation instruction.  $\overrightarrow{\mathsf{RESET}}$  input sets the PCC to 04H.

| Figure 5-2. | Processor | Clock Cont | rol Register | Format |
|-------------|-----------|------------|--------------|--------|
|-------------|-----------|------------|--------------|--------|

| Symbol | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0    | Address | After<br>Reset | R/W |
|--------|---|---|---|---|---|------|------|------|---------|----------------|-----|
| PCC    | 0 | 0 | 0 | 0 | 0 | PCC2 | PCC1 | PCC0 | FFFBH   | 04H            | R/W |

| PCC2  | PCC1                     | PCC0 | CPU Clock Selection (f <sub>CPU</sub> ) |                                         |                                          |  |  |
|-------|--------------------------|------|-----------------------------------------|-----------------------------------------|------------------------------------------|--|--|
|       |                          |      |                                         | MCS=1                                   | MCS=0                                    |  |  |
| 0     | 0                        | 0    | fxx                                     | f <sub>x</sub> (0.4 μs)                 | f <sub>x</sub> /2 (0.8 μs)               |  |  |
| 0     | 0                        | 1    | fxx/2                                   | f <sub>x</sub> /2 (0.8 μs)              | f <sub>x</sub> /2 <sup>2</sup> (1.6 µs)  |  |  |
| 0     | 1                        | 0    | fxx/2 <sup>2</sup>                      | f <sub>x</sub> /2 <sup>2</sup> (1.6 µs) | f <sub>x</sub> /2 <sup>3</sup> (3.2 μs)  |  |  |
| 0     | 1                        | 1    | fxx/2 <sup>3</sup>                      | f <sub>x</sub> /2 <sup>3</sup> (3.2 µs) | f <sub>x</sub> /2 <sup>4</sup> (6.4 μs)  |  |  |
| 1     | 1 0 0 fxx/2 <sup>4</sup> |      | fxx/2 <sup>4</sup>                      | f <sub>x</sub> /2 <sup>4</sup> (6.4 µs) | f <sub>x</sub> /2 <sup>5</sup> (12.8 μs) |  |  |
| Other | r than a                 | bove | Setting prohibite                       | d                                       |                                          |  |  |

Caution Set 0 to the bits 3 to 7.

**Remarks 1.** fxx : Main system clock frequency (fx or fx/2)

- **2.** fx : Main system clock oscillator frequency
- 3. MCS : Bit 0 of oscillation mode selection register (OSMS)
- 4. Figures in parentheses indicate minimum instruction execution time : 2fcPU when operating at fx = 5.0 MHz.

## (2) Oscillation mode selection register (OSMS)

This register specifies whether the clock output from the main system clock oscillator without passing through the scaler is used as the main system clock, or the clock output via the scaler is used as the main system clock.

OSMS is set with 8-bit memory manipulation instruction.

RESET input sets OSMS to 00H.





Cautions 1. Writing to OSMS should be performed only immediately after reset signal release and before peripheral hardware operation starts. As shown in Figure 5-4 below, writing data (including same data as previous) to OSMS cause delay of main system clock cycle up to 2/fx during the write operation. Therefore, if this register is written during the operation, in peripheral hardware which operates with the main system clock, a temporary error occurs in the count clock cycle of timer, etc. In addition, because the oscillation mode is changed by this register, the clocks for peripheral hardware as well as that for the CPU are switched.

## Figure 5-4. Main System Clock Waveform due to Writing to OSMS



2. When writing "1" to MCS, VDD must be 2.7 V or higher before the write execution.

**Remarks** f<sub>xx</sub> : Main system clock frequency (fx or fx/2)

fx : Main system clock oscillation frequency

# 5.4 System Clock Oscillator

#### 5.4.1 Main system clock oscillator

The main system clock oscillator oscillates with a crystal resonator or a ceramic resonator (standard: 5.0 MHz) connected to the X1 and X2 pins.

External clocks can be input to the main system clock oscillator. In this case, input a clock signal to the X1 pin and an antiphase clock signal to the X2 pin.

Figure 5-5 shows an external circuit of the main system clock oscillator.

#### Figure 5-5. External Circuit of Main System Clock Oscillator

(a) Crystal and ceramic oscillation

(b) External clock



Ceramic Resonator

- Cautions 1. Do not execute the STOP instruction if an external clock is used. This is because the X2 pin is connected to VDD via a pull-up register.
  - 2. When using a main system clock oscillator, carry out wiring in the broken line area in Figure 5-5 to prevent any effects from wiring capacities.
    - Minimize the wiring length.
    - Do not allow wiring to intersect with other signal conductors. Do not allow wiring to come near changing high current.
    - Set the potential of the grounding position of the oscillator capacitor to that of Vss. Do not ground to any ground pattern where high current is present.
    - Do not fetch signals from the oscillator.

Figure 5-6 shows examples of oscillator having bad connection.

Figure 5-6. Examples of Oscillator with Bad Connection (1/2)

- (a) Wiring of connection circuits is too long
- (c) Changing high current is too near a signal conductor

with each other  $\begin{array}{c}
 & \text{PORTn} \\
 & (n = 0, 1, 3, 5, 7, 10) \\
 & \text{IC} \qquad X2 \qquad X1 \\
 & \text{IC} \qquad \end{array}$ 

(b) Signal conductors intersect

(d) Current flows through the grounding line of the ocsillator (potential at points A, B, and C fluctuate)

7/7





Figure 5-6. Examples of Oscillator with Bad Connection (2/2)

# (c) Signals are fetched



## 5.4.2 Scaler

The scaler divides the main system clock oscillator output (fxx) and generates various clocks.

## 5.5 Clock Generator Operations

The clock generator generates the following various types of clocks and controls the CPU operating mode including the standby mode.

- Main system clock fxx
- CPU clock fcpu
- Clock to peripheral hardware

The following clock generator functions and operations are determined with the processor clock control register (PCC) and the oscillation mode selection register (OSMS).

- (a) Upon generation of RESET signal, the lowest speed mode of the main system clock (12.8 μs when operated at 5.0 MHz) is selected (PCC = 04H, OSMS = 00H). Main system clock oscillation stops while low level is applied to RESET pin.
- (b) The six types of CPU clocks (0.4  $\mu$ s. 0.8  $\mu$ s, 1.6  $\mu$ s, 3.2  $\mu$ s, 6.4 $\mu$ s, 12.8  $\mu$ s : 5.0 MHz) can be selected by setting the PCC and OSMS.
- (c) Two standby modes, the STOP and HALT modes, are available.
- (d) The main system clock is divided and supplied to the peripheral hardware. Thus, the peripheral hardware also stops if the main system clock is stopped. (Except external input clock operation)

# 5.6 Changing CPU Clock Settings

# 5.6.1 Time required for CPU clock switchover

The CPU clock can be switched over by means of bits 0 to 2 (PCC0 to PCC2) of the processor clock control register (PCC).

The actual switchover operation is not performed directly after writing to the PCC, but operation continues on the pre-switchover clock for several instructions (see **Table 5-2**).

| Set V<br>Switc | alues I<br>hover | oefore            | Set Values After Switchover |          |                 |      |         |                 |         |          |                 |      |          |                |                |       |      |
|----------------|------------------|-------------------|-----------------------------|----------|-----------------|------|---------|-----------------|---------|----------|-----------------|------|----------|----------------|----------------|-------|------|
| PCC2           |                  | PCC0              |                             | PCC1     | PCC0            | PCC2 | PCC1    | PCC0            | PCC2    | PCC1     | PCC0            | PCC2 | PCC1     | PCC0           | PCC2           | PCC1  | PCC0 |
| F 002          | FUUT             | 0 0 0 0 0 1 0 1 0 |                             | 0        | 0               | 1    | 1       | 1               | 0       | 0        |                 |      |          |                |                |       |      |
| 0              | 0                | 0                 |                             |          | 16 instructions |      |         | 16 instructions |         |          | 16 instructions |      |          | 16             | instruc        | tions |      |
| 0              | 0                | 1                 | 8 in                        | structio | ons             |      |         | 8 instructions  |         |          | 8 instructions  |      |          | 8 instructions |                |       |      |
| 0              | 1                | 0                 | 4 in                        | structio | ons             | 4 i  | nstruct | ions            |         |          | 4 instructions  |      | ons      | 4 instructions |                | ions  |      |
| 0              | 1                | 1                 | 2 ir                        | nstructi | ons             | 2 i  | nstruct | ions            | 2 instr |          | ons             |      |          |                | 2 instructions |       |      |
| 1              | 0                | 0                 | 1 in                        | structio | on              | 1 iı | nstruct | ion             | 1 ir    | istructi | on              | 1 ir | nstructi | on             |                |       |      |

# Table 5-2. Maximum Time Required for CPU Clock Switchover

Remark One instruction is the minimum instruction execution time with the pre-switchover CPU clock.

## 5.6.2 CPU clock switching procedure

This section describes CPU clock switching procedure.



Figure 5-7. CPU Clock Switching

- (1) The CPU is reset by setting the RESET signal to low level after power-on. After that, when reset is released by setting the RESET signal to high level, main system clock starts oscillation. At this time, oscillation stabilization time (2<sup>17</sup>/fx) is secured automatically. After that, the CPU starts executing the instruction at the minimum speed of the main system clock (12.8 μs when operated at 5.0 MHz).
- (2) After the lapse of a sufficient time for the VDD voltage to increase to enable operation at maximum speeds, the processor clock control register (PCC) and oscillation mode selection register (OSMS) are rewritten and the maximum-speed operation is carried out.

# CHAPTER 6 8-BIT TIMER/EVENT COUNTERS 5 AND 6

The timers incorporated into the  $\mu$ PD78083 subseries are outlined below.

## (1) 8-bit timers/event counters 5 and 6 (TM5 and TM6)

This can be used to serve as an interval timer, an external event counter, square wave output with any selected frequency PWM, etc. It cannot be used as a 16-bit timer/event counter (See **CHAPTER 6 8-BIT TIMER/EVENT COUNTERS 5 AND 6**).

## (2) Watchdog timer (WDTM)

WDTM can perform the watchdog timer function or generate non-maskable interrupt requests, maskable interrupt requests and RESET at the preset time intervals (See CHAPTER 7 WATCHDOG TIMER).

## (3) Clock output control circuit

This circuit supplies a clock obtained by dividing the main system clock, to other devices (See **CHAPTER 8 CLOCK OUTPUT CONTROL CIRCUIT**).

# (4) Buzzer output control circuit

This circuit outputs the buzzer frequency obtained by dividing the main system clock (See CHAPTER 9 BUZZER OUTPUT CONTROL CIRCUIT).

|          |                        | 8-bit Timer/Event Counters 5 and 6 | Watchdog Timer            |
|----------|------------------------|------------------------------------|---------------------------|
| Туре     | Interval timer         | 2 channels                         | 1 channel <sup>Note</sup> |
|          | External event counter | 1                                  | _                         |
| Function | Timer output           | √                                  | _                         |
|          | PWM output             | $\checkmark$                       | _                         |
|          | Square-wave output     | 1                                  | _                         |
|          | Interrupt request      | $\checkmark$                       |                           |

## Table 6-1 Timer/Event Counter Types and Functions

**Note** Watchdog timer can perform either the watchdog timer function or the interval timer function.

# 6.1 8-Bit Timer/Event Counters 5 and 6 Functions

The 8-bit timer/event counters 5 and 6 (TM5 and TM6) have the following functions.

- Interval timer
- External event counter
- Square-wave output
- PWM output

# (1) 8-bit interval timer

Interrupt requests are generated at the preset time intervals.

| Minimum Ir             | nterval Time           | Maximum Ir             | nterval Time                       | Resolution             |                        |  |  |
|------------------------|------------------------|------------------------|------------------------------------|------------------------|------------------------|--|--|
| MCS = 1                | MCS = 0                | MCS = 1                | MCS = 0                            | MCS = 1                | MCS = 0                |  |  |
| _                      | 1/fx<br>(200 ns)       |                        | 2 <sup>8</sup> × 1/fx<br>(51.2 μs) |                        | 1/fx<br>(200 ns)       |  |  |
| 1/fx                   | 2 × 1/fx               | 2 <sup>8</sup> × 1/fx  | 2 <sup>9</sup> × 1/fx              | 1/fx                   | 2 × 1/fx               |  |  |
| (200 ns)               | (400 ns)               | (51.2 μs)              | (102.4 μs)                         | (200 ns)               | (400 ns)               |  |  |
| 2 × 1/fx               | 2 <sup>2</sup> × 1/fx  | 2 <sup>9</sup> × 1/fx  | 2 <sup>10</sup> × 1/fx             | 2 × 1/fx               | 2 <sup>2</sup> × 1/fx  |  |  |
| (400 ns)               | (800 ns)               | (102.4 μs)             | (204.8 μs)                         | (400 ns)               | (800 ns)               |  |  |
| 2 <sup>2</sup> × 1/fx  | 2 <sup>3</sup> × 1/fx  | 2 <sup>10</sup> × 1/fx | 2 <sup>11</sup> × 1/fx             | 2 <sup>2</sup> × 1/fx  | 2 <sup>3</sup> × 1/fx  |  |  |
| (800 ns)               | (1.6 μs)               | (204.8 μs)             | (409.6 μs)                         | (800 ns)               | (1.6 μs)               |  |  |
| $2^3 \times 1/fx$      | $2^4 \times 1/fx$      | 2 <sup>11</sup> × 1/fx | 2 <sup>12</sup> × 1/fx             | 2 <sup>3</sup> × 1/fx  | $2^4 	imes 1/fx$       |  |  |
| (1.6 µs)               | (3.2 µs)               | (409.6 μs)             | (819.2 μs)                         | (1.6 μs)               | (3.2 $\mu$ s)          |  |  |
| $2^4 \times 1/fx$      | $2^5 \times 1/fx$      | 2 <sup>12</sup> × 1/fx | 2 <sup>13</sup> × 1/fx             | 2 <sup>4</sup> × 1/fx  | 2 <sup>5</sup> × 1/fx  |  |  |
| (3.2 $\mu$ s)          | (6.4 µs)               | (819.2 μs)             | (1.64 ms)                          | (3.2 μs)               | (6.4 μs)               |  |  |
| 2 <sup>5</sup> × 1/fx  | $2^6 \times 1/fx$      | 2 <sup>13</sup> × 1/fx | 2 <sup>14</sup> × 1/fx             | 2 <sup>5</sup> × 1/fx  | 2 <sup>6</sup> × 1/fx  |  |  |
| (6.4 μs)               | (12.8 $\mu$ s)         | (1.64 ms)              | (3.28 ms)                          | (6.4 μs)               | (12.8 μs)              |  |  |
| 2 <sup>6</sup> × 1/fx  | 2 <sup>7</sup> × 1/fx  | 2 <sup>14</sup> × 1/fx | 2 <sup>15</sup> × 1/fx             | 2 <sup>6</sup> × 1/fx  | 2 <sup>7</sup> × 1/fx  |  |  |
| (12.8 μs)              | (25.6 μs)              | (3.28 ms)              | (6.55 ms)                          | (12.8 μs)              | (25.6 μs)              |  |  |
| 2 <sup>7</sup> × 1/fx  | 2 <sup>8</sup> × 1/fx  | 2 <sup>15</sup> × 1/fx | 2 <sup>16</sup> × 1/fx             | 2 <sup>7</sup> × 1/fx  | 2 <sup>8</sup> × 1/fx  |  |  |
| (25.6 μs)              | (51.2 μs)              | (6.55 ms)              | (13.1 ms)                          | (25.6 μs)              | (51.2 μs)              |  |  |
| 2 <sup>8</sup> × 1/fx  | 2 <sup>9</sup> × 1/fx  | 2 <sup>16</sup> × 1/fx | 2 <sup>17</sup> × 1/fx             | 2 <sup>8</sup> × 1/fx  | 2 <sup>9</sup> × 1/fx  |  |  |
| (51.2 μs)              | (102.4 μs)             | (13.1 ms)              | (26.2 ms)                          | (51.2 μs)              | (102.4 μs)             |  |  |
| 2 <sup>9</sup> × 1/fx  | 2 <sup>10</sup> × 1/fx | 2 <sup>17</sup> × 1/fx | 2 <sup>18</sup> × 1/fx             | 2 <sup>9</sup> × 1/fx  | 2 <sup>10</sup> × 1/fx |  |  |
| (102.4 μs)             | (204.8 μs)             | (26.2 ms)              | (52.4 ms)                          | (102.4 μs)             | (204.8 μs)             |  |  |
| 2 <sup>11</sup> × 1/fx | 2 <sup>12</sup> × 1/fx | 2 <sup>19</sup> × 1/fx | 2 <sup>20</sup> × 1/fx             | 2 <sup>11</sup> × 1/fx | 2 <sup>12</sup> × 1/fx |  |  |
| (409.6 μs)             | (819.2 μs)             | (104.9 ms)             | (209.7 ms)                         | (409.6 μs)             | (819.2 μs)             |  |  |

| Table 6-2. 8-Bit Timer/Event Counters 5 and 6 | Interval Times |
|-----------------------------------------------|----------------|
|-----------------------------------------------|----------------|

Remarks 1. fx : Main system clock oscillation frequency

2. MCS : Oscillation mode selection register (OSMS) bit 0

3. Values in parentheses when operated at fx = 5.0 MHz.

# (2) External event counter

The number of pulses of an externally input signal can be measured.

## (3) Square-wave output

A square wave with any selected frequency can be output.

| Minimum p              | oulse width            | Maximum (              | oulse width                        | Reso                   | lution                 |
|------------------------|------------------------|------------------------|------------------------------------|------------------------|------------------------|
| MCS = 1                | MCS = 0                | MCS = 1                | MCS = 0                            | MCS = 1                | MCS = 0                |
| _                      | 1/fx<br>(200 ns)       | _                      | 2 <sup>8</sup> × 1/fx<br>(51.2 μs) | _                      | 1/fx<br>(200 ns)       |
| 1/fx                   | 2 × 1/fx               | 2 <sup>8</sup> × 1/fx  | 2 <sup>9</sup> × 1/fx              | 1/fx                   | 2 × 1/fx               |
| (200 ns)               | (400 ns)               | (51.2 μs)              | (102.4 μs)                         | (200 ns)               | (400 ns)               |
| 2 × 1/fx               | 2 <sup>2</sup> × 1/fx  | 2 <sup>9</sup> × 1/fx  | 2 <sup>10</sup> × 1/fx             | 2 × 1/fx               | 2 <sup>2</sup> × 1/fx  |
| (400 ns)               | (800 ns)               | (102.4 μs)             | (204.8 μs)                         | (400 ns)               | (800 ns)               |
| 2 <sup>2</sup> × 1/fx  | 2 <sup>3</sup> × 1/fx  | 2 <sup>10</sup> × 1/fx | 2 <sup>11</sup> × 1/fx             | 2 <sup>2</sup> × 1/fx  | 2 <sup>3</sup> × 1/fx  |
| (800 ns)               | (1.6 μs)               | (204.8 μs)             | (409.6 μs)                         | (800 ns)               | (1.6 μs)               |
| $2^3 \times 1/fx$      | 2 <sup>4</sup> × 1/fx  | 2 <sup>11</sup> × 1/fx | 2 <sup>12</sup> × 1/fx             | 2 <sup>3</sup> × 1/fx  | $2^4 \times 1/fx$      |
| (1.6 $\mu$ s)          | (3.2 μs)               | (409.6 μs)             | (819.2 μs)                         | (1.6 μs)               | (3.2 µs)               |
| $2^4 \times 1/fx$      | 2 <sup>5</sup> × 1/fx  | 2 <sup>12</sup> × 1/fx | 2 <sup>13</sup> × 1/fx             | 2 <sup>4</sup> × 1/fx  | 2 <sup>5</sup> × 1/fx  |
| (3.2 µs)               | (6.4 μs)               | (819.2 μs)             | (1.64 ms)                          | (3.2 μs)               | (6.4 μs)               |
| $2^5 \times 1/fx$      | 2 <sup>6</sup> × 1/fx  | 2 <sup>13</sup> × 1/fx | 2 <sup>14</sup> × 1/fx             | 2 <sup>5</sup> × 1/fx  | 2 <sup>6</sup> × 1/fx  |
| (6.4 µs)               | (12.8 μs)              | (1.64 ms)              | (3.28 ms)                          | (6.4 μs)               | (12.8 μs)              |
| 2 <sup>6</sup> × 1/fx  | 2 <sup>7</sup> × 1/fx  | 2 <sup>14</sup> × 1/fx | 2 <sup>15</sup> × 1/fx             | 2 <sup>6</sup> × 1/fx  | 2 <sup>7</sup> × 1/fx  |
| (12.8 μs)              | (25.6 μs)              | (3.28 ms)              | (6.55 ms)                          | (12.8 μs)              | (25.6 μs)              |
| $2^7 \times 1/fx$      | 2 <sup>8</sup> × 1/fx  | 2 <sup>15</sup> × 1/fx | 2 <sup>16</sup> × 1/fx             | 2 <sup>7</sup> × 1/fx  | 2 <sup>8</sup> × 1/fx  |
| (25.6 $\mu$ s)         | (51.2 μs)              | (6.55 ms)              | (13.1 ms)                          | (25.6 μs)              | (51.2 μs)              |
| 2 <sup>8</sup> × 1/fx  | 2 <sup>9</sup> × 1/fx  | 2 <sup>16</sup> × 1/fx | 2 <sup>17</sup> × 1/fx             | 2 <sup>8</sup> × 1/fx  | 2 <sup>9</sup> × 1/fx  |
| (51.2 μs)              | (102.4 μs)             | (13.1 ms)              | (26.2 ms)                          | (51.2 μs)              | (102.4 μs)             |
| 2 <sup>9</sup> × 1/fx  | 2 <sup>10</sup> × 1/fx | 2 <sup>17</sup> × 1/fx | 2 <sup>18</sup> × 1/fx             | 2 <sup>9</sup> × 1/fx  | 2 <sup>10</sup> × 1/fx |
| (102.4 μs)             | (204.8 μs)             | (26.2 ms)              | (52.4 ms)                          | (102.4 μs)             | (204.8 μs)             |
| 2 <sup>11</sup> × 1/fx | 2 <sup>12</sup> × 1/fx | 2 <sup>19</sup> × 1/fx | 2 <sup>20</sup> × 1/fx             | 2 <sup>11</sup> × 1/fx | 2 <sup>12</sup> × 1/fx |
| (409.6 μs)             | (819.2 μs)             | (104.9 ms)             | (209.7 ms)                         | (409.6 μs)             | (819.2 μs)             |

Remarks 1. fx : Main system clock oscillation frequency

2. MCS : Oscillation mode selection register (OSMS) bit 0

**3.** Values in parentheses when operated at  $f_x = 5.0$  MHz.

# (4) PWM Output

TM5 and TM6 can generate 8-bit resolution PWM output.

# 6.2 8-Bit Timer/Event Counters 5 and 6 Configurations

The 8-bit timer/event counters 5 and 6 consist of the following hardware.

| Table 6-4. 8-Bit Timer/Event Counters 5 and 6 Configuration | Table 6-4. | 8-Bit Timer/Event | Counters 5 and 6 | Configurations |
|-------------------------------------------------------------|------------|-------------------|------------------|----------------|
|-------------------------------------------------------------|------------|-------------------|------------------|----------------|

| Item             | Configuration                                                                                                                              |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Timer register   | 8 bits $\times$ 2 (TM5, TM6)                                                                                                               |
| Register         | Compare register: 8 bits $\times$ 2 (CR50, CR60)                                                                                           |
| Timer output     | 2 (TO5, TO6)                                                                                                                               |
| Control register | Timer clock select register 5 and 6 (TCL5, TCL6)<br>8-bit timer mode control register 5 and 6 (TMC5, TMC6)<br>Port mode register 10 (PM10) |

Figure 6-1. 8-Bit Timer/Event Counters 5 and 6 Block Diagram





**Remark** n = 5, 6



Figure 6-2. Block Diagram of 8-Bit Timer/Event Counters 5 and 6 Output Control Circuit

Note PM100 : Bit 0 of port mode register 10 (PM10) PM101 : Bit 1 of PM10

**Remarks 1.** The section in the broken line is an output control circuit. **2.** n = 5, 6

## (1) Compare registers 50 and 60 (CR50, CR60)

These are 8-bit registers to compare the value set to CR50 to the 8-bit timer register 5 (TM5) count value, and the value set to CR60 to the 8-bit timer register 6 (TM6) count value, and, if they match, generate an interrupt request (INTTM5 and INTTM6, respectively).

CR50 and CR60 are set with an 8-bit memory manipulation instruction. They cannot be set with a 16-bit memory manipulation instruction. The 00H to FFH values can be set. RESET input sets CR50 and CR60 to 00H.

# Caution When using the PWM mode, please set the CRn0 value before setting TMCn (n=5, 6) to the PWM mode.

## (2) 8-bit timer registers 5 and 6 (TM5, TM6)

These are 8-bit registers to count count pulses. TM5 and TM6 are read with an 8-bit memory manipulation instruction.  $\overrightarrow{\mathsf{RESET}}$  input sets TM5 and TM6 to 00H.

# 6.3 8-Bit Timer/Event Counters 5 and 6 Control Registers

The following three types of registers are used to control the 8-bit timer/event counter 5 and 6.

- Timer clock select register 5 and 6 (TCL5, TCL6)
- 8-bit timer mode control register 5 and 6 (TMC5, TMC6)
- Port mode register 10 (PM10)

## (1) Timer clock select register 5 (TCL5)

This register sets count clocks of 8-bit timer register 5. TCL5 is set with an 8-bit memory manipulation instruction.  $\overrightarrow{\text{RESET}}$  input sets TCL5 to 00H.

| TCL5 | 0     | 0          | 0       | 0     | TCL53               | TCL52                                      | TCL51              | FCL50               | FF5     | 52H | 00H |                    | R/W        |  |
|------|-------|------------|---------|-------|---------------------|--------------------------------------------|--------------------|---------------------|---------|-----|-----|--------------------|------------|--|
| 1    |       |            |         |       |                     |                                            |                    |                     |         |     |     |                    |            |  |
|      |       |            |         | TCL50 |                     | Bit Timer Register 5 Count Clock Selection |                    |                     |         |     |     |                    |            |  |
|      | TOLOG | TOLUZ      | TOLST   | ICL50 |                     |                                            | MCS                | 5=1                 |         |     |     | MCS=               | 0          |  |
|      | 0     | 0          | 0       | 0     | TI5 fa              | 5 falling edge <sup>Note</sup>             |                    |                     |         |     |     |                    |            |  |
|      | 0     | 0          | 0       | 1     | TI5 ris             | 5 rising edge <sup>Note</sup>              |                    |                     |         |     |     |                    |            |  |
|      | 0     | 1          | 0       | 0     | 2fxx                |                                            | Setti              | ng proh             | nibited |     |     | fx                 | (5.0 MHz)  |  |
|      | 0     | 1          | 0       | 1     | fxx                 |                                            | fx                 | (5.0 N              | MHz)    |     |     | fx/2               | (2.5 MHz)  |  |
|      | 0     | 1          | 1       | 0     | fxx/2               |                                            | fx/2               | (2.5 N              | MHz)    |     |     | fx/2 <sup>2</sup>  | (1.25 MHz) |  |
|      | 0     | 1          | 1       | 1     | fxx/2 <sup>2</sup>  |                                            | fx/2 <sup>2</sup>  | (1.25               | MHz)    |     |     | $f_x/2^3$          | (625 kHz)  |  |
|      | 1     | 0          | 0       | 0     | fxx/2 <sup>3</sup>  |                                            | fx/2 <sup>3</sup>  | (625                | kHz)    |     |     | fx/2 <sup>4</sup>  | (313 kHz)  |  |
|      | 1     | 0          | 0       | 1     | fxx/2 <sup>4</sup>  |                                            | fx/24              | (313                | kHz)    |     |     | fx/2 <sup>5</sup>  | (156 kHz)  |  |
|      | 1     | 0          | 1       | 0     | fxx/2 <sup>5</sup>  |                                            | fx/2 <sup>5</sup>  | (156                | kHz)    |     |     | fx/2 <sup>6</sup>  | (78.1 kHz) |  |
|      | 1     | 0          | 1       | 1     | fxx/2 <sup>6</sup>  |                                            | fx/2 <sup>6</sup>  | (78.1               | kHz)    |     |     | fx/2 <sup>7</sup>  | (39.1 kHz) |  |
|      | 1     | 1          | 0       | 0     | fxx/2 <sup>7</sup>  |                                            | fx/2 <sup>7</sup>  | (39.1               | kHz)    |     |     | fx/2 <sup>8</sup>  | (19.5 kHz) |  |
|      | 1     | 1          | 0       | 1     | fxx/2 <sup>8</sup>  |                                            | fx/2 <sup>8</sup>  | (19.5               | kHz)    |     |     | fx/2 <sup>9</sup>  | (9.8 kHz)  |  |
|      | 1     | 1          | 1       | 0     | fxx/2 <sup>9</sup>  |                                            | fx/2 <sup>9</sup>  | (9.8 k              | (Hz)    |     |     | fx/2 <sup>10</sup> | (4.9 kHz)  |  |
|      | 1     | 1          | 1       | 1     | fxx/2 <sup>11</sup> |                                            | fx/2 <sup>11</sup> | <sup>l</sup> (2.4 k | (Hz)    |     |     | fx/2 <sup>12</sup> | (1.2 kHz)  |  |
|      | С     | Other that | an abov | e     | Settin              | Setting prohibited                         |                    |                     |         |     |     |                    |            |  |

# Figure 6-3. Timer Clock Select Register 5 Format

3 2 1 0

Symbol 7 6 5

4

Address After Reset

R/W

**Note** The timer output (PWM output) cannot be used in cases where the clock is being input from an external source.

# Caution When rewriting TCL5 to other data, stop the timer operation beforehand.

**Remarks 1.** fxx : Main system clock frequency (fx or fx/2)

- 2. fx : Main system clock oscillation frequency
- 3. TI5 : 8-bit timer register 5 input pin
- 4. MCS : Oscillation mode selection register (OSMS) bit 0
- 5. Values in parentheses when operated at fx = 5.0 MHz

## (2) Timer clock select register 6 (TCL6)

This register sets count clocks of 8-bit timer register 6. TCL6 is set with an 8-bit memory manipulation instruction. RESET input sets TCL6 to 00H.

#### Figure 6-4. Timer Clock Select Register 6 Format

| Symbol | 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     | Address | After Reset |
|--------|---|---|---|---|-------|-------|-------|-------|---------|-------------|
| TCL6   | 0 | 0 | 0 | 0 | TCL63 | TCL62 | TCL61 | TCL60 | FF56H   | 00H         |

|        | TCL63 TCL62      |       |       |                              | 8-bit Timer Register 6 Count C | lock Sele          | ection     |
|--------|------------------|-------|-------|------------------------------|--------------------------------|--------------------|------------|
| IICL63 | I CL62           | ICL61 | TCL60 |                              | MCS=1                          |                    | MCS=0      |
| 0      | 0                | 0     | 0     | TI6 falling edge             | Note                           |                    |            |
| 0      | 0                | 0     | 1     | TI6 rising edge <sup>™</sup> | ote                            |                    |            |
| 0      | 1                | 0     | 0     | 2fxx                         | Setting prohibited             | fx                 | (5.0 MHz)  |
| 0      | 1                | 0     | 1     | fxx                          | fx (5.0 MHz)                   | fx/2               | (2.5 MHz)  |
| 0      | 1                | 1     | 0     | fxx/2                        | fx/2 (2.5 MHz)                 | fx/2 <sup>2</sup>  | (1.25 MHz) |
| 0      | 1                | 1     | 1     | fxx/2 <sup>2</sup>           | fx/2 <sup>2</sup> (1.25 MHz)   | fx/2 <sup>3</sup>  | (625 kHz)  |
| 1      | 0                | 0     | 0     | fxx/2 <sup>3</sup>           | fx/2 <sup>3</sup> (625 kHz)    | fx/2 <sup>4</sup>  | (313 kHz)  |
| 1      | 0                | 0     | 1     | fxx/2 <sup>4</sup>           | fx/2 <sup>4</sup> (313 kHz)    | fx/2 <sup>5</sup>  | (156 kHz)  |
| 1      | 0                | 1     | 0     | fxx/2 <sup>5</sup>           | fx/2 <sup>5</sup> (156 kHz)    | fx/2 <sup>6</sup>  | (78.1 kHz) |
| 1      | 0                | 1     | 1     | fxx/2 <sup>6</sup>           | fx/2 <sup>6</sup> (78.1 kHz)   | fx/2 <sup>7</sup>  | (39.1 kHz) |
| 1      | 1                | 0     | 0     | fxx/2 <sup>7</sup>           | fx/2 <sup>7</sup> (39.1 kHz)   | fx/2 <sup>8</sup>  | (19.5 kHz) |
| 1      | 1                | 0     | 1     | fxx/2 <sup>8</sup>           | fx/2 <sup>8</sup> (19.5 kHz)   | fx/2 <sup>9</sup>  | (9.8 kHz)  |
| 1      | 1                | 1     | 0     | fxx/2 <sup>9</sup>           | fx/2 <sup>9</sup> (9.8 kHz)    | fx/2 <sup>10</sup> | (4.9 kHz)  |
| 1      | 1                | 1     | 1     | fxx/2 <sup>11</sup>          | fx/2 <sup>11</sup> (2.4 kHz)   | fx/2 <sup>12</sup> | (1.2 kHz)  |
| 0      | Other than above |       |       | Setting prohibite            | ed                             |                    |            |

Note When clock is input from the external, timer output (PWM output) cannot be used.

Caution When rewriting TCL6 to other data, stop the timer operation beforehand.

**Remarks 1.** fxx : Main system clock frequency (fx or fx/2)

- 2. fx : Main system clock oscillation frequency
- 3. TI6 : 8-bit timer register 6 input pin
- 4. MCS : Oscillation mode selection register (OSMS) bit 0
- 5. Values in parentheses when operated at fx = 5.0 MHz

## (3) 8-bit timer mode control register 5 (TMC5)

This register enables/stops operation of 8-bit timer register 5, sets the operating mode of 8-bit timer register 5 and controls operation of 8-bit timer/event counter 5 output control circuit.

It sets R-S type flip-flop (timer output F/F 1,2) setting/resetting, the active level in PWM mode, inversion enabling/disabling in modes other than PWM mode and 8-bit timer/event counter 5 timer output enabling/ disabling.

TMC5 is set with a 1-bit or 8-bit memory manipulation instruction.

RESET input sets TMC5 to 00H.

| Symbol | 7    | 6     | 5 | 4 | 3    | 2    | 1    | 0     | A     | ddress                                        | After Reset            | R/W                                     |
|--------|------|-------|---|---|------|------|------|-------|-------|-----------------------------------------------|------------------------|-----------------------------------------|
| TMC5   | TCE5 | TMC56 | 0 | 0 | LVS5 | LVR5 | TMC5 | 1 TOE | i i   | F53H                                          | 00H                    | R/W                                     |
| -      |      |       |   |   |      |      |      |       | -     |                                               |                        |                                         |
|        |      |       |   |   |      |      |      |       | TOE5  | 8-                                            | Bit Timer/Event Co     | ounter 5 Output Control                 |
|        |      |       |   |   |      |      |      |       | 0     | Outpu                                         | It disabled (Port mo   | ode)                                    |
|        |      |       |   |   |      |      |      |       | 1     | Outpu                                         | it enabled             |                                         |
|        |      |       |   |   |      |      |      |       |       |                                               |                        |                                         |
|        |      |       |   |   |      |      |      |       | TMC51 | lı                                            | n PWM Mode             | In Other Modes                          |
|        |      |       |   |   |      |      |      |       |       | Activ                                         | ve level selection     | Timer output F/F1 control               |
|        |      |       |   |   |      |      |      |       | 0     | Active                                        | e high                 | Inversion operation disabled            |
|        |      |       |   |   |      |      |      |       | 1     | Active                                        | e low                  | Inversion operation enabled             |
|        |      |       |   |   |      |      |      |       |       |                                               |                        | ·                                       |
|        |      |       |   |   |      |      |      |       | LVS5  | LVR5                                          |                        | Event Counter 5 Timer<br>Status Setting |
|        |      |       |   |   |      |      |      |       | 0     | 0                                             | No change              |                                         |
|        |      |       |   |   |      |      |      |       | 0     | 1                                             | Timer output F/F       | 1 reset (0)                             |
|        |      |       |   |   |      |      |      |       | 1     | 0                                             | Timer output F/F       | 1 set (1)                               |
|        |      |       |   |   |      |      |      |       | 1     | 1                                             | Setting prohibited     | ł                                       |
|        |      |       |   |   |      |      |      |       | THOSE | 0.0                                           | T                      | E On another Marke Oaks if              |
|        |      | L     |   |   |      |      |      |       | TMC56 |                                               |                        | 5 Operating Mode Selection              |
|        |      |       |   |   |      |      |      |       | 0     | Clear &                                       | & start mode on mate   | h of TM5 and CR50                       |
|        |      |       |   |   |      |      |      |       | 1     | PWM r                                         | mode (free-running)    |                                         |
|        |      |       |   |   |      |      |      |       | TOFE  |                                               |                        |                                         |
|        |      |       |   |   |      |      |      |       |       | TCE5 8-Bit Timer Register 5 Operation Control |                        |                                         |
|        |      |       |   |   |      |      |      |       | 0     | -                                             | tion stop (TM5 clear t | O U)                                    |
|        |      |       |   |   |      |      |      |       | 1     | Operat                                        | tion enable            |                                         |

## Figure 6-5. 8-Bit Timer Mode Control Register 5 Format

Cautions 1. Timer operation must be stopped before setting TMC5.

- 2. If LVS5 and LVR5 are read after data are set, they will be 0.
- 3. Set 0 to the bits 4 and 5.

#### (4) 8-bit timer mode control register 6 (TMC6)

This register enables/stops operation of 8-bit timer register 6, sets the operating mode of 8-bit timer register 6 and controls operation of 8-bit timer/event counter 6 output control circuit.

It sets R-S type flip-flop (timer output F/F 1,2) setting/resetting, active level in PWM mode, inversion enabling/ disabling in modes other than PWM mode and 8-bit timer/event counter 6 timer output enabling/disabling. <u>TMC6 is set with a 1-bit or 8-bit memory manipulation instruction</u>.

RESET input sets TMC6 to 00H.

| Symbol 7  | 6     | 5 | 4 | 3    | 2    | 1    | 0      | A      | ddress                                      | After Reset                     | R/W                                    |
|-----------|-------|---|---|------|------|------|--------|--------|---------------------------------------------|---------------------------------|----------------------------------------|
| TMC6 TCE6 | TMC66 | 0 | 0 | LVS6 | LVR6 | TMC6 | 1 TOE6 | F      | F57H                                        | 00H                             | R/W                                    |
|           |       |   |   |      |      |      |        | •      |                                             |                                 |                                        |
|           |       |   |   |      |      |      |        | TOE6   | 8-                                          | Bit Timer/Event Co              | unter 6 Output Control                 |
|           |       |   |   |      |      |      |        | 0      | Outpu                                       | t disabled (Port mo             | ode)                                   |
|           |       |   |   |      |      |      |        | 1      | Outpu                                       | it enabled                      |                                        |
|           |       |   |   |      |      |      |        |        |                                             |                                 |                                        |
|           |       |   |   |      |      |      |        | TMC61  | II                                          | n PWM Mode                      | In Other Modes                         |
|           |       |   |   |      |      |      |        | 111001 | Activ                                       | ve level selection              | Timer output F/F1 control              |
|           |       |   |   |      |      |      |        | 0      | Active                                      | high                            | Inversion operation disabled           |
|           |       |   |   |      |      |      |        | 1      | Active                                      | e low                           | Inversion operation enabled            |
|           |       |   |   |      |      |      |        |        |                                             |                                 |                                        |
|           |       |   |   |      |      |      |        | LVS6   | LVR6                                        | 8-Bit Timer/E<br>Output F/F1 \$ | vent Counter 6 Timer<br>Status Setting |
|           |       |   |   |      |      |      |        | 0      | 0                                           | No change                       |                                        |
|           |       |   |   |      |      |      |        | 0      | 1                                           | Timer output F/F                | 1 reset (0)                            |
|           |       |   |   |      |      |      |        | 1      | 0                                           | Timer output F/F                | 1 set (1)                              |
|           |       |   |   |      |      |      |        | 1      | 1                                           | Setting prohibited              | 1                                      |
|           |       |   |   |      |      |      |        | TMC66  | 8-Bit                                       | Timer/Event Counter             | 6 Operating Mode Selection             |
|           |       |   |   |      |      |      |        | 0      |                                             | start mode on matc              |                                        |
|           |       |   |   |      |      |      |        | 1      |                                             | mode (free-running)             |                                        |
|           |       |   |   |      |      |      |        | 1      | 1 1111                                      |                                 |                                        |
|           |       |   |   |      |      |      |        | TCE6   | E6 8-Bit Timer Register 6 Operation Control |                                 |                                        |
|           |       |   |   |      |      |      |        | 0      | 0 Operation Stop (TM6 clear to 0)           |                                 |                                        |
|           |       |   |   |      |      |      |        | 1      | Operat                                      | tion Enable                     |                                        |

#### Figure 6-6. 8-Bit Timer Mode Control Register 6 Format

Cautions 1. Timer operation must be stopped before setting TMC6.

- 2. If LVS6 and LVR6 are read after data are set, they will be 0.
- 3. Set 0 to the bits 4 and 5.

# (5) Port mode register 10 (PM10)

This register sets port 10 input/output in 1-bit units.

When using the P100/TI5/TO5 and P101/TI6/TO6 pins for timer output, set PM100, PM101, and output latches of P100 and P101 to 0.

PM10 is set with a 1-bit or 8-bit memory manipulation instruction.

RESET input sets PM10 to FFH.

#### Figure 6-7. Port Mode Register 10 Format



Caution Set 1 to the bits 2 to 7.

# 6.4 8-Bit Timer/Event Counters 5 and 6 Operations

#### 6.4.1 Interval timer operations

By setting the 8-bit timer mode control registers 5 and 6 (TMC5 and TMC6) as shown in Figure 6-8, it can be operated as an interval timer. The 8-bit timer/event counters 5 and 6 operate as interval timers which generate interrupt requests repeatedly at intervals of the count value preset to 8-bit compare registers 50 and 60 (CR50 and CR60).

When the count values of the 8-bit timer registers 5 and 6 (TM5 and TM6) match the values set to CR50 and CR60, counting continues with the TM5 and TM6 values cleared to 0 and the interrupt request signals (INTTM5 and INTTM6) are generated.

Count clock of TM5 can be selected with the timer clock select register 5 (TCL5). Count clock of TM6 can be selected with the timer clock select register 6 (TCL6).





**Remarks 1.** 0/1 : Setting 0 or 1 allows another function to be used simultaneously with the interval timer. See 6.3 (3), (4) for details.

**2.** n = 5, 6



Figure 6-9. Interval Timer Operation Timings

**Remarks 1.** Interval time =  $(N + 1) \times t$  : N = 00H to FFH **2.** n = 5, 6

| TOLEO  | TOLEO     |         |       | Minimum In                              | terval Time                          | Maximum Ir                           | nterval Time                         | Reso                                 | lution                               |
|--------|-----------|---------|-------|-----------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|
| I CLN3 | TCLn2     | ICLNI   | ICLNU | MCS = 1                                 | MCS = 0                              | MCS = 1                              | MCS = 0                              | MCS = 1                              | MCS = 0                              |
| 0      | 0         | 0       | 0     | TIn input cycle                         |                                      | 2 <sup>8</sup> × TIn i               | nput cycle                           | TIn input edge cycle                 |                                      |
| 0      | 0         | 0       | 1     | TIn inpu                                | ut cycle                             | 2 <sup>8</sup> × TIn i               | nput cycle                           | TIn input e                          | edge cycle                           |
| 0      | 1         | 0       | 0     | Setting prohibited                      | 1/fx<br>(200 ns)                     | Setting prohibited                   | 2 <sup>8</sup> × 1/fx<br>(51.2 μs)   | Setting prohibited                   | 1/fx<br>(200 ns)                     |
| 0      | 1         | 0       | 1     | 1/fx<br>(200 ns)                        | 2 × 1/fx<br>(400 ns)                 | 2 <sup>8</sup> × 1/fx<br>(51.2 μs)   | 2 <sup>9</sup> × 1/fx<br>(102.4 μs)  | 1/fx<br>(200 ns)                     | 2 × 1/fx<br>(400 ns)                 |
| 0      | 1         | 1       | 0     | 2 × 1/fx<br>(400 ns)                    | 2 <sup>2</sup> × 1/fx<br>(800 ns)    | 2 <sup>9</sup> × 1/fx<br>(102.4 μs)  | 2 <sup>10</sup> × 1/fx<br>(204.8 μs) | 2 × 1/fx<br>(400 ns)                 | 2 <sup>2</sup> × 1/fx<br>(800 ns)    |
| 0      | 1         | 1       | 1     | 2 <sup>2</sup> × 1/fx<br>(800 ns)       | 2 <sup>3</sup> × 1/fx<br>(1.6 μs)    | 2 <sup>10</sup> × 1/fx<br>(204.8 μs) | 2 <sup>11</sup> × 1/fx<br>(409.6 μs) | 2 <sup>2</sup> × 1/fx<br>(800 ns)    | 2 <sup>3</sup> × 1/fx<br>(1.6 μs)    |
| 1      | 0         | 0       | 0     | 2 <sup>3</sup> × 1/fx<br>(1.6 μs)       | 2 <sup>4</sup> × 1/fx<br>(3.2 μs)    | 2 <sup>11</sup> × 1/fx<br>(409.6 μs) | 2 <sup>12</sup> × 1/fx<br>(819.2 μs) | 2 <sup>3</sup> × 1/fx<br>(1.6 μs)    | $2^4 	imes 1/fx$<br>(3.2 $\mu$ s)    |
| 1      | 0         | 0       | 1     | $2^4 \times 1/fx$<br>(3.2 $\mu$ s)      | 2 <sup>5</sup> × 1/fx<br>(6.4 μs)    | 2 <sup>12</sup> × 1/fx<br>(819.2 μs) | 2 <sup>13</sup> × 1/fx<br>(1.64 ms)  | 2 <sup>4</sup> × 1/fx<br>(3.2 μs)    | 2 <sup>5</sup> × 1/fx<br>(6.4 μs)    |
| 1      | 0         | 1       | 0     | 2 <sup>5</sup> × 1/fx<br>(6.4 μs)       | 2 <sup>6</sup> × 1/fx<br>(12.8 μs)   | 2 <sup>13</sup> × 1/fx<br>(1.64 ms)  | 2 <sup>14</sup> × 1/fx<br>(3.28 ms)  | 2 <sup>5</sup> × 1/fx<br>(6.4 μs)    | 2 <sup>6</sup> × 1/fx<br>(12.8 μs)   |
| 1      | 0         | 1       | 1     | 2 <sup>6</sup> × 1/fx<br>(12.8 μs)      | 2 <sup>7</sup> × 1/fx<br>(25.6 μs)   | 2 <sup>14</sup> × 1/fx<br>(3.28 ms)  | 2 <sup>15</sup> × 1/fx<br>(6.55 ms)  | 2 <sup>6</sup> × 1/fx<br>(12.8 μs)   | 2 <sup>7</sup> × 1/fx<br>(25.6 μs)   |
| 1      | 1         | 0       | 0     | 2 <sup>7</sup> × 1/fx<br>(25.6 μs)      | 2 <sup>8</sup> × 1/fx<br>(51.2 μs)   | 2 <sup>15</sup> × 1/fx<br>(6.55 ms)  | 2 <sup>16</sup> × 1/fx<br>(13.1 ms)  | 2 <sup>7</sup> × 1/fx<br>(25.6 μs)   | 2 <sup>8</sup> × 1/fx<br>(51.2 μs)   |
| 1      | 1         | 0       | 1     | 2 <sup>8</sup> × 1/fx<br>(51.2 μs)      | 2 <sup>9</sup> × 1/fx<br>(102.4 μs)  | 2 <sup>16</sup> × 1/fx<br>(13.1 ms)  | 2 <sup>17</sup> × 1/fx<br>(26.2 ms)  | 2 <sup>8</sup> × 1/fx<br>(51.2 μs)   | 2 <sup>9</sup> × 1/fx<br>(102.4 μs)  |
| 1      | 1         | 1       | 0     | 2 <sup>9</sup> × 1/fx<br>(102.4 μs)     | 2 <sup>10</sup> × 1/fx<br>(204.8 μs) | 2 <sup>17</sup> × 1/fx<br>(26.2 ms)  | 2 <sup>18</sup> × 1/fx<br>(52.4 ms)  | 2 <sup>9</sup> × 1/fx<br>(102.4 μs)  | 2 <sup>10</sup> × 1/fx<br>(204.8 μs) |
| 1      | 1         | 1       | 1     | $2^{11} \times 1/fx$<br>(409.6 $\mu$ s) | $2^{12} \times 1/fx$<br>(819.2 µs)   | 2 <sup>19</sup> × 1/fx<br>(104.9 ms) | 2 <sup>20</sup> × 1/fx<br>(209.7 ms) | 2 <sup>11</sup> × 1/fx<br>(409.6 μs) | 2 <sup>12</sup> × 1/fx<br>(819.2 μs) |
| 0      | ther that | an abov | /e    | Setting prohi                           | bited                                | ·                                    | ·                                    |                                      |                                      |

| Table 6-5. | 8-Bit Timer/Event Counters 5 and 6 Interval Times |
|------------|---------------------------------------------------|
|            |                                                   |

**Remarks 1.** fx : Main system clock oscillation frequency

**2.** MCS : Oscillation mode selection register (OSMS) bit 0

**3.** Values in parentheses when operated at fx = 5.0 MHz.

**4.** n = 5, 6

#### 6.4.2 External event counter operation

The external event counter counts the number of external clock pulses to be input to the TI5/PI00/TO5 and TI6/ P101/TO6 pins with 8-bit timer registers 5 and 6 (TM5 and TM6).

TM5 and TM6 are incremented each time the valid edge specified with the timer clock select register 5 and 6 (TCL5 and TCL6) is input. Either the rising or falling edge can be selected.

When the TM5 and TM6 counted values match the values of 8-bit compare registers 50 and 60 (CR50 and CR60), TM5 and TM6 are cleared to 0 and the interrupt request signals (INTTM5 and INTTM6) are generated.

Figure 6-10. 8-Bit Timer Mode Control Register Setting for External Event Counter Operation



**Remarks 1.** n = 5, 6 **2.** ×: don't care



| Count Clock     |                                                                 |
|-----------------|-----------------------------------------------------------------|
| TMn Count Value | 00 X 01 X 02 X 03 X 04 X 05 X X X N-1 X N X 00 X 01 X 02 X 03 X |
| CRn0            | N                                                               |
| TCEn            |                                                                 |
| INTTMn          |                                                                 |

**Remarks 1.** N = 00H to FFH **2.** n = 5, 6

## 6.4.3 Square-wave output

This makes the value set in advance in the 8-bit conveyor register 50, 60 (CR50, CR60) to be the interval. It operates as a square wave output at the desired frequency.

The TO5/P100/TI5 or TO6/P101/TI6 pin output status is reversed at intervals of the count value preset to CR50 or CR60 by setting bit 1 (TMC51) and bit 0 (TOE5) of 8-bit timer output control register 5 (TMC5), or bit 1 (TMC61) and bit 0 (TOE6) of 8-bit timer mode control register 6 (TMC6) to 1.

This enables a square wave of any selected frequency to be output.





# Caution When TI5/P100/TO5 or TI6/P101/TO6 pin is used as the timer output, set 0 to port mode register (PM100 or PM101) and output latch (P100 or P101).

**Remark** n = 5, 6

| Minimum F                  | Pulse Width            | Maximum F              | Pulse Width                        | Resolution             |                        |  |
|----------------------------|------------------------|------------------------|------------------------------------|------------------------|------------------------|--|
| MCS = 1                    | MCS = 0                | MCS = 1                | MCS = 0                            | MCS = 1                | MCS = 0                |  |
| _                          | 1/fx<br>(200 ns)       | _                      | 2 <sup>8</sup> × 1/fx<br>(51.2 μs) | _                      | 1/fx<br>(200 ns)       |  |
| 1/fx                       | 2 × 1/fx               | 2 <sup>8</sup> × 1/fx  | 2 <sup>9</sup> × 1/fx              | 1/fx                   | 2 × 1/fx               |  |
| (200 ns)                   | (400 ns)               | (51.2 μs)              | (102.4 μs)                         | (200 ns)               | (400 ns)               |  |
| 2 × 1/fx                   | 2 <sup>2</sup> × 1/fx  | 2 <sup>9</sup> × 1/fx  | 2 <sup>10</sup> × 1/fx             | 2 × 1/fx               | 2 <sup>2</sup> × 1/fx  |  |
| (400 ns)                   | (800 ns)               | (102.4 μs)             | (204.8 μs)                         | (400 ns)               | (800 ns)               |  |
| 2 <sup>2</sup> × 1/fx      | 2 <sup>3</sup> × 1/fx  | 2 <sup>10</sup> × 1/fx | 2 <sup>11</sup> × 1/fx             | 2 <sup>2</sup> × 1/fx  | 2 <sup>3</sup> × 1/fx  |  |
| (800 ns)                   | (1.6 μs)               | (204.8 μs)             | (409.6 μs)                         | (800 ns)               | (1.6 μs)               |  |
| $2^3 \times 1/fx$          | 2 <sup>4</sup> × 1/fx  | 2 <sup>11</sup> × 1/fx | 2 <sup>12</sup> × 1/fx             | 2 <sup>3</sup> × 1/fx  | 2 <sup>4</sup> × 1/fx  |  |
| (1.6 µs)                   | (3.2 μs)               | (409.6 μs)             | (819.2 μs)                         | (1.6 μs)               | (3.2 μs)               |  |
| $2^4 \times 1/fx$ (3.2 µs) | 2 <sup>5</sup> × 1/fx  | 2 <sup>12</sup> × 1/fx | 2 <sup>13</sup> × 1/fx             | 2 <sup>4</sup> × 1/fx  | 2 <sup>5</sup> × 1/fx  |  |
|                            | (6.4 μs)               | (819.2 μs)             | (1.64 ms)                          | (3.2 μs)               | (6.4 μs)               |  |
| $2^5 \times 1/fx$          | 2 <sup>6</sup> × 1/fx  | 2 <sup>13</sup> × 1/fx | 2 <sup>14</sup> × 1/fx             | 2 <sup>5</sup> × 1/fx  | 2 <sup>6</sup> × 1/fx  |  |
| (6.4 $\mu$ s)              | (12.8 μs)              | (1.64 ms)              | (3.28 ms)                          | (6.4 μs)               | (12.8 μs)              |  |
| $2^6 \times 1/fx$          | 2 <sup>7</sup> × 1/fx  | 2 <sup>14</sup> × 1/fx | 2 <sup>15</sup> × 1/fx             | 2 <sup>6</sup> × 1/fx  | 2 <sup>7</sup> × 1/fx  |  |
| (12.8 µs)                  | (25.6 μs)              | (3.28 ms)              | (6.55 ms)                          | (12.8 μs)              | (25.6 μs)              |  |
| $2^7 \times 1/fx$          | 2 <sup>8</sup> × 1/fx  | 2 <sup>15</sup> × 1/fx | 2 <sup>16</sup> × 1/fx             | 2 <sup>7</sup> × 1/fx  | 2 <sup>8</sup> × 1/fx  |  |
| (25.6 µs)                  | (51.2 μs)              | (6.55 ms)              | (13.1 ms)                          | (25.6 μs)              | (51.2 μs)              |  |
| 2 <sup>8</sup> × 1/fx      | 2 <sup>9</sup> × 1/fx  | 2 <sup>16</sup> × 1/fx | 2 <sup>17</sup> × 1/fx             | 2 <sup>8</sup> × 1/fx  | 2 <sup>9</sup> × 1/fx  |  |
| (51.2 μs)                  | (102.4 μs)             | (13.1 ms)              | (26.2 ms)                          | (51.2 μs)              | (102.4 μs)             |  |
| 2 <sup>9</sup> × 1/fx      | 2 <sup>10</sup> × 1/fx | 2 <sup>17</sup> × 1/fx | 2 <sup>18</sup> × 1/fx             | 2 <sup>9</sup> × 1/fx  | 2 <sup>10</sup> × 1/fx |  |
| (102.4 μs)                 | (204.8 μs)             | (26.2 ms)              | (52.4 ms)                          | (102.4 μs)             | (204.8 μs)             |  |
| 2 <sup>11</sup> × 1/fx     | 2 <sup>12</sup> × 1/fx | 2 <sup>19</sup> × 1/fx | 2 <sup>20</sup> × 1/fx             | 2 <sup>11</sup> × 1/fx | 2 <sup>12</sup> × 1/fx |  |
| (409.6 μs)                 | (819.2 μs)             | (104.9 ms)             | (209.7 ms)                         | (409.6 μs)             | (819.2 μs)             |  |

Table 6-6. 8-Bit Timer/Event Counters 5 and 6 Square-Wave Output Ranges

Remarks 1. fx : Main system clock oscillation frequency

2. MCS : Oscillation mode selection register (OSMS) bit 0

**3.** Values in parentheses when operated at fx = 5.0 MHz.

## 6.4.4 PWM output operations

Setting the 8-bit timer mode control registers 5 and 6 (TMC5 and TMC6) as shown in Figure 6-13 allows operation as PWM output. Pulses with the duty ratio determined by the values preset in the 8-bit compare registers 50 and 60 (CR50 and CR60) output from the TO5/P100/TI5 or TO6/P101/TI6 pin.

Select the active level of PWM pulse with bit 1 (TMC51) of 8-bit timer mode control register 5 (TMC5) or bit 1 (TMC61) of 8-bit timer mode control register 6 (TMC6).

This PWM pulse has an 8-bit resolution. The pulse can be converted into an analog voltage by integrating it with an external low-pass filter (LPF). Count clock of 8-bit timer register 5 (TM5) can be selected with timer clock select register 5 (TCL5) and count clock of 8-bit timer register 6 (TM6) can be selected with timer clock select register 6 (TCL6).

PWM output enable/disable can be selected with bit 0 (TOE5) of TMC5 or bit 0 (TOE6) of TMC6.

#### Figure 6-13. 8-Bit Timer Mode Control Register Settings for PWM Output Operation



#### Remarks 1. n = 5, 6

**2.**  $\times$  : don't care



Figure 6-14. PWM Output Operation Timing (Active high setting)

**Remark** n = 5, 6











**Remark** n = 5, 6



Figure 6-17. PWM Output Operation Timings (CRn0 changing, active high setting)

Caution If CRn0 is changed during TMn operation, the value changed is not reflected until TMn overflows.

Remark n = 5, 6

## 6.5 Cautions on 8-Bit Timer/Event Counters 5 and 6

#### (1) Timer start errors

An error with a maximum of one clock may occur concerning the time required for a match signal to be generated after timer start. This is because 8-bit timer registers 5 and 6 (TM5 and TM6) are started asynchronously with the count pulse.





#### (2) 8-bit compare register 50 and 60 setting

The 8-bit compare registers 50 and 60 (CR50 and CR60) can be set to 00H.

Thus, when these 8-bit compare registers are used as event counters, one-pulse count operation can be carried out.





#### (3) Operation after compare register change during timer count operation

If the values after the 8-bit compare registers 50 and 60 (CR50 and CR60) are changed are smaller than those of 8-bit timer registers 5 and 6 (TM5 and TM6), TM5 and TM6 continue counting, overflow and then restart counting from 0. Thus, if the value (M) after CR50 and CR60 change is smaller than value (N) before the change, it is necessary to restart the timer after changing CR50 and CR60.





 $\textbf{Remark} \quad N > X > M$ 

# CHAPTER 7 WATCHDOG TIMER

## 7.1 Watchdog Timer Functions

The watchdog timer has the following functions.

- Watchdog timer
- Interval timer

# Caution Select the watchdog timer mode or the interval timer mode with the watchdog timer mode register (WDTM) (The watchdog timer and interval timer cannot be used at the same time).

## (1) Watchdog timer mode

An inadvertent program loop is detected. Upon detection of the inadvertent program loop, a non-maskable interrupt request or RESET can be generated.

| Runaway Detection Time | MCS = 1                         | MCS = 0                          |
|------------------------|---------------------------------|----------------------------------|
| $2^{11} \times 1/fxx$  | 2 <sup>11</sup> × 1/fx (410 µs) | 2 <sup>12</sup> × 1/fx (819 μs)  |
| $2^{12} \times 1/fxx$  | 2 <sup>12</sup> × 1/fx (819 μs) | $2^{13} \times 1/fx$ (1.64 ms)   |
| $2^{13} \times 1$ /fxx | $2^{13} \times 1/fx$ (1.64 ms)  | $2^{14} \times 1/fx$ (3.28 ms)   |
| $2^{14} \times 1/fxx$  | $2^{14} \times 1/fx$ (3.28 ms)  | $2^{15} \times 1/fx$ (6.55 ms)   |
| $2^{15} \times 1$ /fxx | $2^{15} \times 1/fx$ (6.55 ms)  | $2^{16} \times 1/fx$ (13.1 ms)   |
| $2^{16} \times 1/fxx$  | $2^{16} \times 1/fx$ (13.1 ms)  | $2^{17} \times 1/fx$ (26.2 ms)   |
| $2^{17} \times 1/fxx$  | $2^{17} \times 1/fx$ (26.2 ms)  | 2 <sup>18</sup> × 1/fx (52.4 ms) |
| $2^{19} \times 1$ /fxx | $2^{19} \times 1/fx$ (104.9 ms) | $2^{20} \times 1/fx$ (209.7 ms)  |

#### Table 7-1. Watchdog Timer Overrun Detection Times

Remarks 1. fxx : Main system clock frequency (fx or fx/2)

- 2. fx : Main system clock oscillation frequency
- 3. MCS : Oscillation mode selection register (OSMS) bit 0
- **4.** Values in parentheses when operated at fx = 5.0 MHz.

# (2) Interval timer mode

Interrupt requests are generated at the preset time intervals.

| Interval Time          | MCS = 1                            | CS = 0                            |
|------------------------|------------------------------------|-----------------------------------|
| $2^{11} \times 1/fxx$  | $2^{11} \times 1/fx$ (410 $\mu$ s) | 2 <sup>12</sup> × 1/fx (819 μs)   |
| $2^{12} \times 1/fxx$  | $2^{12} \times 1/fx$ (819 $\mu$ s) | 2 <sup>13</sup> × 1/fx (1.64 ms)  |
| $2^{13} \times 1$ /fxx | 2 <sup>13</sup> × 1/fx (1.64 ms)   | 2 <sup>14</sup> × 1/fx (3.28 ms)  |
| $2^{14} \times 1/fxx$  | 2 <sup>14</sup> × 1/fx (3.28 ms)   | 2 <sup>15</sup> × 1/f× (6.55 ms)  |
| $2^{15} \times 1/fxx$  | $2^{15} \times 1/fx$ (6.55 ms)     | 2 <sup>16</sup> × 1/fx (13.1 ms)  |
| $2^{16} 	imes 1/fxx$   | $2^{16} \times 1/fx$ (13.1 ms)     | 2 <sup>17</sup> × 1/fx (26.2 ms)  |
| $2^{17} \times 1/fxx$  | $2^{17} \times 1/fx$ (26.2 ms)     | $2^{18} \times 1/fx$ (52.4 ms)    |
| $2^{19} 	imes 1/fxx$   | $2^{19} \times 1/fx$ (104.9 ms)    | 2 <sup>20</sup> × 1/fx (209.7 ms) |

#### Table 7-2. Interval Times

**Remarks 1.** fxx : Main system clock frequency (fx or fx/2)

2. fx : Main system clock oscillation frequency

3. MCS : Oscillation mode selection register (OSMS) bit 0

4. Values in parentheses when operated at fx = 5.0 MHz.

# 7.2 Watchdog Timer Configuration

The watchdog timer consists of the following hardware.

Table 7-3. Watchdog Timer Configuration

| Item             | Configuration                                                               |  |  |  |  |
|------------------|-----------------------------------------------------------------------------|--|--|--|--|
| Control register | Timer clock select register 2 (TCL2)<br>Watchdog timer mode register (WDTM) |  |  |  |  |





# 7.3 Watchdog Timer Control Registers

The following two types of registers are used to control the watchdog timer.

- Timer clock select register 2 (TCL2)
- Watchdog timer mode register (WDTM)

# (1) Timer clock select register 2 (TCL2)

This register sets the watchdog timer count clock. TCL2 is set with 8-bit memory manipulation instruction.  $\ensuremath{\overline{\mathsf{RESET}}}$  input sets TCL2 to 00H.

**Remark** Besides setting the watchdog timer count clock, TCL2 sets the buzzer output frequency.

| Symbol<br>TCL2 |       |       | 5<br>TCL25 |                     | 3 2<br>0 TCL2 | 1<br>22 TCL21                |                              | Address<br>FF42H | After<br>Reset<br>00H | R/W<br>R/W             |
|----------------|-------|-------|------------|---------------------|---------------|------------------------------|------------------------------|------------------|-----------------------|------------------------|
|                | TCL22 | TCL21 | TCL20      |                     | dog Timer (   | Count Clo<br>MCS=1           |                              | n                | MCS                   | =0                     |
|                | 0     | 0     | 0          | $f_{XX}/2^3$        |               | fx/2 <sup>3</sup> (625 kHz)  |                              |                  |                       | (313 kHz)              |
|                | 0     | 0     | 1          | $f_{XX}/2^4$        |               | fx/2 <sup>4</sup> (313 kHz)  |                              |                  | fx/2 <sup>5</sup>     | (156 kHz)              |
|                | 0     | 1     | 0          | fxx/2 <sup>5</sup>  |               | fx/2 <sup>5</sup> (156 kHz)  |                              |                  | fx/2 <sup>6</sup>     | (78.1 kHz)             |
|                | 0     | 1     | 1          | fxx/2 <sup>6</sup>  |               | fx/2 <sup>6</sup> (78.1 kHz) |                              |                  | fx/2 <sup>7</sup>     | (39.1 kHz)             |
|                | 1     | 0     | 0          | $f_{XX}/2^7$        |               | fx/2 <sup>7</sup> (39.1 kHz) |                              |                  | fx/2 <sup>8</sup>     | (19.5 kHz)             |
|                | 1     | 0     | 1          | fxx/2 <sup>8</sup>  |               | fx/2 <sup>8</sup> (          | fx/2 <sup>8</sup> (19.5 kHz) |                  |                       | (9.8 kHz)              |
|                | 1     | 1     | 0          | fxx/2 <sup>9</sup>  |               | fx/2 <sup>9</sup> (          | fx/2 <sup>9</sup> (9.8 kHz)  |                  |                       | <sup>0</sup> (4.9 kHz) |
|                | 1     | 1     | 1          | fxx/2 <sup>11</sup> |               | fx/2 <sup>11</sup> (2        | 2.4 kHz)                     |                  | fx/2 <sup>12</sup>    | <sup>2</sup> (1.2 kHz) |

# Figure 7-2. Timer Clock Select Register 2 Format

| TOLOT | TCL27 TCL26 TCL2 |   | Buzzer Output Frequency Selection |                              |                              |  |  |  |  |  |
|-------|------------------|---|-----------------------------------|------------------------------|------------------------------|--|--|--|--|--|
|       |                  |   |                                   | MCS=1                        | MCS=0                        |  |  |  |  |  |
| 0     | ×                | × | Buzzer output disa                | Buzzer output disable        |                              |  |  |  |  |  |
| 1     | 0                | 0 | fxx/2 <sup>9</sup>                | fx/2 <sup>9</sup> (9.8 kHz)  | fx/2 <sup>10</sup> (4.9 kHz) |  |  |  |  |  |
| 1     | 0                | 1 | fxx/2 <sup>10</sup>               | fx/2 <sup>10</sup> (4.9 kHz) | fx/2 <sup>11</sup> (2.4 kHz) |  |  |  |  |  |
| 1     | 1                | 0 | fxx/2 <sup>11</sup>               | fx/2 <sup>11</sup> (2.4 kHz) | fx/2 <sup>12</sup> (1.2 kHz) |  |  |  |  |  |
| 1     | 1                | 1 | Setting prohibited                |                              |                              |  |  |  |  |  |

# Caution 1. When rewriting TCL2 to other data, stop the timer operation beforehand. 2. Set 0 to the bits 3 and 4.

- **Remarks 1.** fxx : Main system clock frequency (fx or fx/2)
  - **2.** fx : Main system clock oscillation frequency
  - **3.** × : Don't care

- 4. MCS : Oscillation mode selection register (OSMS) bit 0
- **5.** Values in parentheses when operated at fx = 5.0 MHz.

## (2) Watchdog timer mode register (WDTM)

This register sets the watchdog timer operating mode and enables/disables counting. WDTM is set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets WDTM to 00H.



#### Figure 7-3. Watchdog Timer Mode Register Format

- Notes 1. Once set to 1, WDTM3 and WDTM4 cannot be cleared to 0 by software.
  - 2. The watchdog timer starts operating as an interval timer as soon as RUN has been set to 1.
    - 3. Once set to 1, RUN cannot be cleared to 0 by software.

Thus, once counting starts, it can only be stopped by  $\overline{\mathsf{RESET}}$  input.

- Cautions 1. When 1 is set in RUN so that the watchdog timer is cleared, the actual overflow time is up to 0.5 % shorter than the time set by timer clock select register 2.
  - 2. To use watchdog timer modes 1 and 2, make sure that the interrupt request flag (TMIF4) is 0, and then set WDTM4 to 1.

If WDTM4 is set to 1 when TMIF4 is 1, the non-maskable interrupt request occurs, regardless of the contents of WDTM3.

Remark ×: Don't care

#### 7.4 Watchdog Timer Operations

### 7.4.1 Watchdog timer operation

When bit 4 (WDTM4) of the watchdog timer mode register (WDTM) is set to 1, the watchdog timer is operated to detect any inadvertent program loop.

The watchdog timer count clock (inadvertent program loop detection time interval) can be selected with bits 0 to 2 (TCL20 to TCL22) of the timer clock select register 2 (TCL2).

Watchdog timer starts by setting bit 7 (RUN) of WDTM to 1. After the watchdog timer is started, set RUN to 1 within the set overrun detection time interval. The watchdog timer can be cleared and counting is started by setting RUN to 1. If RUN is not set to 1 and the inadvertent program loop detection time is past, system reset or a non-maskable interrupt request is generated according to the WDTM bit 3 (WDTM3) value.

By setting RUN to 1, the watchdog timer can be cleared.

The watchdog timer continues operating in the HALT mode but it stops in the STOP mode. Thus, set RUN to 1 before the STOP mode is set, clear the watchdog timer and then execute the STOP instruction.

# Caution The actual overrun detection time may be shorter than the set time by a maximum of 0.5 %.

| TCL22 | TCL21 | TCL20 | Runaway Detection Time | MCS = 1                                      | MCS = 0                           |
|-------|-------|-------|------------------------|----------------------------------------------|-----------------------------------|
| 0     | 0     | 0     | $2^{11} \times 1/fxx$  | $2^{11} 	imes 1$ /fx (410 $\mu$ s)           | $2^{12} 	imes 1/fx$ (819 $\mu$ s) |
| 0     | 0     | 1     | $2^{12} \times 1/fxx$  | $2^{12}	imes 1/	ext{fx}$ (819 $\mu	ext{s}$ ) | $2^{13} \times 1/fx$ (1.64 ms)    |
| 0     | 1     | 0     | $2^{13} \times 1/fxx$  | $2^{13} \times 1/fx$ (1.64 ms)               | $2^{14} \times 1/fx$ (3.28 ms)    |
| 0     | 1     | 1     | $2^{14} \times 1/fxx$  | $2^{14} \times 1/fx$ (3.28 ms)               | 2 <sup>15</sup> × 1/fx (6.55 ms)  |
| 1     | 0     | 0     | $2^{15} \times 1$ /fxx | 2 <sup>15</sup> × 1/fx (6.55 ms)             | 2 <sup>16</sup> × 1/fx (13.1 ms)  |
| 1     | 0     | 1     | $2^{16} \times 1/fxx$  | 2 <sup>16</sup> × 1/fx (13.1 ms)             | $2^{17} \times 1/fx$ (26.2 ms)    |
| 1     | 1     | 0     | $2^{17} \times 1/fxx$  | $2^{17} \times 1/fx$ (26.2 ms)               | $2^{18} \times 1/fx$ (52.4 ms)    |
| 1     | 1     | 1     | $2^{19} \times 1/fxx$  | $2^{19} 	imes 1/fx$ (104.9 ms)               | $2^{20} \times 1/f_X$ (209.7 ms)  |

Table 7-4. Watchdog Timer Overrun Detection Time

Remarks 1. fxx : Main system clock frequency (fx or fx/2)

2. fx : Main system clock oscillation frequency

3. MCS: Oscillation mode selection register (OSMS) bit 0

**4.** Values in parentheses when operated at fx = 5.0 MHz.

## 7.4.2 Interval timer operation

 $\star$ 

- The watchdog timer operates as an interval timer which generates interrupt requests repeatedly at an interval of the preset count value when bit 4 (WDTM4) of the watchdog timer mode register (WDTM) is set to 0.
- A count clock (interval time) can be selected by the bits 0 to 2 (TCL20 to TCL22) of the timer clock select register 2 (TCL2). By setting the bit 7 (RUN) of WDTM to 1, the watchdog timer starts operating as an interval timer.

When the watchdog timer operated as interval timer, the interrupt mask flag (TMMK4) and priority specify flag (TMPR4) are validated and the maskable interrupt request (INTWDT) can be generated. Among maskable interrupt requests, the INTWDT default has the highest priority.

The interval timer continues operating in the HALT mode but it stops in STOP mode. Thus, set bit 7 (RUN) of WDTM to 1 before the STOP mode is set, clear the interval timer and then execute the STOP instruction.

# Cautions 1. Once bit 4 (WDTM4) of WDTM is set to 1 (with the watchdog timer mode selected), the interval timer mode is not set unless RESET input is applied.

2. The interval time just after setting with WDTM may be shorter than the set time by a maximum of 0.5 %.

| TCL22 | TCL21 | TCL20 | Interval Time          | MCS = 1                            | MCS = 0                           |
|-------|-------|-------|------------------------|------------------------------------|-----------------------------------|
| 0     | 0     | 0     | $2^{11} \times 1/fxx$  | $2^{11} 	imes 1$ /fx (410 $\mu$ s) | $2^{12} 	imes 1/fx$ (819 $\mu$ s) |
| 0     | 0     | 1     | $2^{12} \times 1/fxx$  | $2^{12} 	imes 1/fx$ (819 $\mu$ s)  | $2^{13} \times 1/fx$ (1.64 ms)    |
| 0     | 1     | 0     | $2^{13} \times 1/fxx$  | $2^{13} \times 1/fx$ (1.64 ms)     | $2^{14} \times 1/fx$ (3.28 ms)    |
| 0     | 1     | 1     | $2^{14} \times 1/fxx$  | $2^{14} \times 1/fx$ (3.28 ms)     | $2^{15} \times 1/fx$ (6.55 ms)    |
| 1     | 0     | 0     | $2^{15} \times 1$ /fxx | $2^{15} 	imes 1$ /fx (6.55 ms)     | 2 <sup>16</sup> × 1/fx (13.1 ms)  |
| 1     | 0     | 1     | $2^{16} \times 1/fxx$  | 2 <sup>16</sup> × 1/fx (13.1 ms)   | $2^{17} \times 1/fx$ (26.2 ms)    |
| 1     | 1     | 0     | $2^{17} \times 1/fxx$  | $2^{17} \times 1/fx$ (26.2 ms)     | 2 <sup>18</sup> × 1/fx (52.4 ms)  |
| 1     | 1     | 1     | $2^{19} \times 1/fxx$  | $2^{19} \times 1$ /fx (104.9 ms)   | $2^{20} \times 1/fx$ (209.7 ms)   |

Table 7-5. Interval Timer Interval Time

**Remarks 1.** fxx : Main system clock frequency (fx or fx/2)

- 2. fx : Main system clock oscillation frequency
- 3. MCS: Oscillation mode selection register (OSMS) bit 0
- 4. Values in parentheses when operated at fx = 5.0 MHz.

# **CHAPTER 8 CLOCK OUTPUT CONTROL CIRCUIT**

## 8.1 Clock Output Control Circuit Functions

The clock output control circuit is intended for carrier output during remote controlled transmission and clock output for supply to peripheral LSI. Clocks selected with the timer clock select register 0 (TCL0) are output from the PCL/ P35 pin.

Follow the procedure below to output clock pulses.

- (1) Select the clock pulse output frequency (with clock pulse output disabled) with bits 0 to 3 (TCL00 to TCL03) of TCL0.
- (2) Set the P35 output latch to 0.
- (3) Set bit 5 (PM35) of port mode register 3 to 0 (set to output mode).
- (4) Set bit 7 (CLOE) of timer clock select register 0 to 1.

## Caution Clock output cannot be used when setting P35 output latch to 1.

**Remark** When clock output enable/disable is switched, the clock output control circuit does not output pulses with small widths (See the portions marked with \* in **Figure 8-1**).





# 8.2 Clock Output Control Circuit Configuration

The clock output control circuit consists of the following hardware.

# Table 8-1. Clock Output Control Circuit Configuration

| Item             | Configuration                        |
|------------------|--------------------------------------|
| Control register | Timer clock select register 0 (TCL0) |
| Control register | Port mode register 3 (PM3)           |



# Figure 8-2. Clock Output Control Circuit Block Diagram

Figure 8-3. Timer Clock Select Register 0 Format

# 8.3 Clock Output Function Control Registers

The following two types of registers are used to control the clock output function.

- Timer clock select register 0 (TCL0)
- Port mode register 3 (PM3)

## (1) Timer clock select register 0 (TCL0)

This register sets PCL output clock. TCL0 is set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets TCL0 to 00H.

| Symbol | $\overline{\mathcal{O}}$ | 6 | 5 | 4 | 3     | 2     | 1     | 0     | Address | After<br>Reset | R/W |
|--------|--------------------------|---|---|---|-------|-------|-------|-------|---------|----------------|-----|
| TCL0   | CLOE                     | 0 | 0 | 0 | TCL03 | TCL02 | TCL01 | TCL00 | FF40H   | 00H            | R/W |

|       |                         |   |       | PCL Output Cl      | ock Selection                |                              |  |  |  |
|-------|-------------------------|---|-------|--------------------|------------------------------|------------------------------|--|--|--|
| TCL03 | TCL03 TCL02 TCL01 TCL00 |   | ICL00 |                    | MCS=1                        | MCS=0                        |  |  |  |
| 0     | 1                       | 0 | 1     | fxx                | fx (5.0 MHz)                 | fx/2 (2.5 MHz)               |  |  |  |
| 0     | 1                       | 1 | 0     | fxx/2              | fx/2 (2.5 MHz)               | fx/2 <sup>2</sup> (1.25 MHz) |  |  |  |
| 0     | 1                       | 1 | 1     | fxx/2 <sup>2</sup> | fx/2 <sup>2</sup> (1.25 MHz) | fx/2 <sup>3</sup> (625 kHz)  |  |  |  |
| 1     | 0                       | 0 | 0     | fxx/2 <sup>3</sup> | fx/2 <sup>3</sup> (625 kHz)  | fx/2 <sup>4</sup> (313 kHz)  |  |  |  |
| 1     | 0                       | 0 | 1     | fxx/2 <sup>4</sup> | fx/2 <sup>4</sup> (313 kHz)  | fx/2 <sup>5</sup> (156 kHz)  |  |  |  |
| 1     | 0                       | 1 | 0     | fxx/2 <sup>5</sup> | fx/2⁵ (156 kHz)              | fx/2 <sup>6</sup> (78.1 kHz) |  |  |  |
| 1     | 0                       | 1 | 1     | fxx/2 <sup>6</sup> | fx/2 <sup>6</sup> (78.1 kHz) | fx/2 <sup>7</sup> (39.1 kHz) |  |  |  |
| 1     | 1                       | 0 | 0     | fxx/2 <sup>7</sup> | fx/2 <sup>7</sup> (39.1 kHz) | fx/2 <sup>8</sup> (19.5 kHz) |  |  |  |
| Oth   | Other than above        |   |       | Setting prohibite  | Setting prohibited           |                              |  |  |  |

| [ | CLOE | PCL Output Control |  |  |  |  |  |  |
|---|------|--------------------|--|--|--|--|--|--|
|   | 0    | Output disable     |  |  |  |  |  |  |
|   | 1    | Output enable      |  |  |  |  |  |  |

# Cautions 1. When enabling PCL output, set TCL00 to TCL03, then set 1 in CLOE with a 1-bit memory manipulation instruction.

- 2. When rewriting TCL0 to other data, stop the clock operation beforehand.
- 3. Set 0 to bits 4 to 6.

\*

**Remarks 1.** fxx : Main system clock frequency (fx or fx/2)

- 2. fx : Main system clock oscillation frequency
- 3. MCS : Oscillation mode selection register (OSMS) bit 0
- 4. Values in parentheses when operated at fx = 5.0 MHz.

### (2) Port mode register 3 (PM3)

This register set port 3 input/output in 1-bit units. When using the P35/PCL pin for clock output function, set PM35 and output latch of P35 to 0. <u>PM3 is</u> set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets PM3 to FFH.

# Figure 8-4. Port Mode Register 3 Format



# CHAPTER 9 BUZZER OUTPUT CONTROL CIRCUIT

# 9.1 Buzzer Output Control Circuit Functions

The buzzer output control circuit outputs 1.2 kHz, 2.4 kHz, 4.9 kHz, or 9.8 kHz frequency square waves. The buzzer frequency selected with timer clock select register 2 (TCL2) is output from the BUZ/P36 pin. Follow the procedure below to output the buzzer frequency.

- (1) Select the buzzer output frequency with bits 5 to 7 (TCL25 to TCL27) of TCL2.
- (2) Set the P36 output latch to 0.
- (3) Set bit 6 (PM36) of port mode register 3 to 0 (Set to output mode).

# Caution Buzzer output cannot be used when setting P36 output latch to 1.

## 9.2 Buzzer Output Control Circuit Configuration

The buzzer output control circuit consists of the following hardware.

| Table 9-1. | Buzzer | Output | Control | Circuit | Configuration |
|------------|--------|--------|---------|---------|---------------|
|------------|--------|--------|---------|---------|---------------|

| Item             | Configuration                                                      |
|------------------|--------------------------------------------------------------------|
| Control register | Timer clock select register 2 (TCL2)<br>Port mode register 3 (PM3) |

### Figure 9-1. Buzzer Output Control Circuit Block Diagram



# 9.3 Buzzer Output Function Control Registers

The following two types of registers are used to control the buzzer output function.

- Timer clock select register 2 (TCL2)
- Port mode register 3 (PM3)
- (1) Timer clock select register 2 (TCL2)

This register sets the buzzer output frequency. TCL2 is set with an 8-bit memory manipulation instruction. RESET input sets TCL2 to 00H.

**Remark** Besides setting the buzzer output frequency, TCL2 sets the watchdog timer count clock.

| Symbol | 7     | 6     | 5     | 4 | 3 | 2     | 1     | 0     | Address | After<br>Reset | R/W |
|--------|-------|-------|-------|---|---|-------|-------|-------|---------|----------------|-----|
| TCL2   | TCL27 | TCL26 | TCL25 | 0 | 0 | TCL22 | TCL21 | TCL20 | FF42H   | 00H            | R/W |

| Figure 9-2. | Timer Cloc | k Select | <b>Register 2</b> | Format |
|-------------|------------|----------|-------------------|--------|
|-------------|------------|----------|-------------------|--------|

|        | TCL22 TCL21 TCL20 |   | Watchdog Timer Count Clock Selection |                              |                              |  |  |  |  |
|--------|-------------------|---|--------------------------------------|------------------------------|------------------------------|--|--|--|--|
| I CL22 |                   |   |                                      | MCS=1                        | MCS=0                        |  |  |  |  |
| 0      | 0                 | 0 | fxx/2 <sup>3</sup>                   | fx/2 <sup>3</sup> (625 kHz)  | fx/2 <sup>4</sup> (313 kHz)  |  |  |  |  |
| 0      | 0                 | 1 | fxx/2 <sup>4</sup>                   | fx/2 <sup>4</sup> (313 kHz)  | fx/2 <sup>5</sup> (156 kHz)  |  |  |  |  |
| 0      | 1                 | 0 | fxx/2 <sup>5</sup>                   | fx/2⁵ (156 kHz)              | fx/2 <sup>6</sup> (78.1 kHz) |  |  |  |  |
| 0      | 1                 | 1 | fxx/2 <sup>6</sup>                   | fx/2 <sup>6</sup> (78.1 kHz) | fx/2 <sup>7</sup> (39.1 kHz) |  |  |  |  |
| 1      | 0                 | 0 | fxx/2 <sup>7</sup>                   | fx/2 <sup>7</sup> (39.1 kHz) | fx/2 <sup>8</sup> (19.5 kHz) |  |  |  |  |
| 1      | 0                 | 1 | fxx/2 <sup>8</sup>                   | fx/2 <sup>8</sup> (19.5 kHz) | fx/2 <sup>9</sup> (9.8 kHz)  |  |  |  |  |
| 1      | 1                 | 0 | fxx/2 <sup>9</sup>                   | fx/2 <sup>9</sup> (9.8 kHz)  | fx/2 <sup>10</sup> (4.9 kHz) |  |  |  |  |
| 1      | 1                 | 1 | fxx/2 <sup>11</sup>                  | fx/2 <sup>11</sup> (2.4 kHz) | fx/2 <sup>12</sup> (1.2 kHz) |  |  |  |  |

| TCL27 | TCL26 | TCL25 | Buzzer Output Frequency Selection |                              |                              |
|-------|-------|-------|-----------------------------------|------------------------------|------------------------------|
|       |       |       |                                   | MCS=1                        | MCS=0                        |
| 0     | ×     | ×     | Buzzer output disable             |                              |                              |
| 1     | 0     | 0     | fxx/2 <sup>9</sup>                | fx/2 <sup>9</sup> (9.8 kHz)  | fx/2 <sup>10</sup> (4.9 kHz) |
| 1     | 0     | 1     | fxx/2 <sup>10</sup>               | fx/2 <sup>10</sup> (4.9 kHz) | fx/2 <sup>11</sup> (2.4 kHz) |
| 1     | 1     | 0     | fxx/2 <sup>11</sup>               | fx/2 <sup>11</sup> (2.4 kHz) | fx/2 <sup>12</sup> (1.2 kHz) |
| 1     | 1     | 1     | Setting prohibited                |                              |                              |

# Cautions 1. When rewriting TCL2 to other data, stop the timer operation beforehand. 2. Set 0 to bits 3 and 4.

**Remarks 1.** fxx : Main system clock frequency (fx or fx/2)

- **2.** fx : Main system clock oscillation frequency
- **3.**  $\times$  : don't care
- 4. MCS : Oscillation mode selection register (OSMS) bit 0
- 5. Values in parentheses when operated at fx = 5.0 MHz

#### (2) Port mode register 3 (PM3)

This register sets port 3 input/output in 1-bit units. When using the P36/BUZ pin for buzzer output function, set PM36 and output latch of P36 to 0. PM3 is set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets PM3 to FFH.



# Figure 9-3. Port Mode Register 3 Format

# CHAPTER 10 A/D CONVERTER

## 10.1 A/D Converter Functions

The A/D converter converts an analog input into a digital value. It consists of 8 channels (ANI0 to ANI7) with an 8-bit resolution.

The conversion method is based on successive approximation and the conversion result is held in the 8-bit A/D conversion result register (ADCR).

The following two ways are available to start A/D conversion.

## (1) Hardware start

Conversion is started by trigger input (INTP3).

#### (2) Software start

Conversion is started by setting the A/D converter mode register.

Select 1 channel of analog input from ANI0 to ANI7 and perform A/D conversion. As for A/D conversion operations, when the hardware is started up, the A/D conversion operation stops when A/D conversion is completed, and an interrupt request (INTAD) is generated. In the case of software start, the A/D conversion operation is repeated. Each time an A/D conversion operation ends, an interrupt request (INTAD) is generated.

## 10.2 A/D Converter Configuration

The A/D converter consists of the following hardware.

| Item             | Configuration                                                                                                                 |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Analog input     | 8 Channels (ANI0 to ANI7)                                                                                                     |  |  |  |  |
| Control register | A/D converter mode register (ADM)<br>A/D converter input select register (ADIS)<br>External interrupt mode register 1 (INTM1) |  |  |  |  |
| Register         | Successive approximation register (SAR)<br>A/D conversion result register (ADCR)                                              |  |  |  |  |

| Table 10-1. | A/D Converte | r Configuration |
|-------------|--------------|-----------------|
|-------------|--------------|-----------------|



#### Figure 10-1. A/D Converter Block Diagram

- Notes 1. Selector to select the number of channels to be used for analog input.
  - 2. Selector to select the channel for A/D conversion.
  - 3. External interrupt mode register 1 (INTM1) bits 0 and 1.

╈

#### (1) Successive approximation register (SAR)

This register compares the analog input voltage value to the voltage tap (compare voltage) value applied from the series resistor string and holds the result from the most significant bit (MSB).

When held to the least significant bit (LSB) (end of A/D conversion), the contents of the SAR are transferred to the A/D conversion results register.

#### (2) A/D conversion result register (ADCR)

This register holds the A/D conversion result. Each time A/D conversion terminates, the conversion result is loaded from the successive approximation register.

ADCR is read with an 8-bit memory manipulation instruction.

RESET input makes ADCR undefined.

# (3) Sample & hold circuit

The sample & hold circuit samples each analog input signal sequentially applied from the input circuit and sends it to the voltage comparator. This circuit holds the sampled analog input voltage value during A/D conversion.

#### (4) Voltage comparator

The voltage comparator compares the analog input to the series resistor string output voltage.

#### (5) Series resistor string

The series resistor string is connected within AVREF to AVss and generates a voltage for comparison with the analog input.

#### (6) ANI0 to ANI7 pins

These are 8-channel analog input pins to input analog signals to undergo A/D conversion to the A/D converter. Pins other than those selected as analog input by the A/D converter input select register (ADIS) can be used as input/output ports.

# Caution Use ANI0 to ANI7 input voltages within the specified range. If a voltage higher than AVREF or lower than AVss is applied (even if within the absolute maximum ratings), the converted value of the corresponding channel becomes indeterminate and may adversely affect the converted values of other channels.

#### (7) AVREF pin

This pin inputs the A/D converter reference voltage.

It converts signals input to ANI0 to ANI7 into digital signals according to the voltage applied between AV<sub>REF</sub> and AV<sub>ss</sub>.

The current flowing in the series resistor string can be reduced by setting the voltage to be input to the AV<sub>REF</sub> pin to AVss level in standby mode.

#### (8) AVss pin

This is a GND potential pin of the A/D converter. Keep it at the same potential as the Vss pin when not using the A/D converter.

#### (9) AVDD pin

This is an A/D converter analog power supply pin. Keep it at the same potential as the Vss pin when not using the A/D converter.

#### 10.3 A/D Converter Control Registers

The following three types of registers are used to control the A/D converter.

- A/D converter mode register (ADM)
- A/D converter input select register (ADIS)
- External interrupt mode register 1 (INTM1)

#### (1) A/D converter mode register (ADM)

This register sets the analog input channel for A/D conversion, conversion time, conversion start/stop and external trigger.

 $\mbox{ADM}$  is set with a 1-bit or 8-bit memory manipulation instruction.  $\mbox{RESET}$  input sets ADM to 01H.

| Symbol | $\overline{\mathcal{O}}$ | 6   | 5   | 4   | 3    | 2    | 1    | 0   | Address | After<br>Reset | R/W |
|--------|--------------------------|-----|-----|-----|------|------|------|-----|---------|----------------|-----|
| ADM    | CS                       | TRG | FR1 | FR0 | ADM3 | ADM2 | ADM1 | HSC | FF80H   | 01H            | R/W |

#### Figure 10-2. A/D Converter Mode Register Format

| ADM3 | ADM2 | ADM1 | Analog Input Channel Selection |
|------|------|------|--------------------------------|
| 0    | 0    | 0    | ANIO                           |
| 0    | 0    | 1    | ANI1                           |
| 0    | 1    | 0    | ANI2                           |
| 0    | 1    | 1    | ANI3                           |
| 1    | 0    | 0    | ANI4                           |
| 1    | 0    | 1    | ANI5                           |
| 1    | 1    | 0    | ANI6                           |
| 1    | 1    | 1    | ANI7                           |

 $\star$ 

★

|                                     |     |     | A/D Conversion Time Selection <sup>Note 1</sup>           |                                               |                                                           |                 |  |  |  |  |  |  |
|-------------------------------------|-----|-----|-----------------------------------------------------------|-----------------------------------------------|-----------------------------------------------------------|-----------------|--|--|--|--|--|--|
| FR1                                 | FR0 | HSC | fx=5.0 MHz Operation                                      |                                               | fx=4.19 MHz Operation                                     |                 |  |  |  |  |  |  |
|                                     |     |     | MCS=1                                                     | MCS=0                                         | MCS=1                                                     | MCS=0           |  |  |  |  |  |  |
| 0                                   | 0   | 1   | $80/f \times (\text{Setting prohibited}^{\text{Note 2}})$ | 160/f× (32.0µs)                               | 80/f× (19.1µs)                                            | 160/fx (38.1µs) |  |  |  |  |  |  |
| 0                                   | 1   | 1   | $40/f \times (\text{Setting prohibited}^{\text{Note 2}})$ | 80/fx (Setting prohibited <sup>Note 2</sup> ) | 40/f× (Setting prohibited <sup>Note 2</sup> )             | 80/fx (19.1µs)  |  |  |  |  |  |  |
| 1                                   | 0   | 0   | $50/f \times (\text{Setting prohibited}^{\text{Note 2}})$ | 100/f× (20.0µs)                               | $50/f \times (\text{Setting prohibited}^{\text{Note 2}})$ | 100/fx (23.8µs) |  |  |  |  |  |  |
| 1                                   | 0   | 1   | 100/fx (20.0µs)                                           | 200/fx (40.0µs)                               | 100/fx (23.8µs)                                           | 200/fx (47.7µs) |  |  |  |  |  |  |
| Other than above Setting prohibited |     |     |                                                           |                                               |                                                           |                 |  |  |  |  |  |  |

| TR | G | External Trigger Selection                               |
|----|---|----------------------------------------------------------|
| 0  |   | No external trigger (software starts)                    |
| 1  |   | Conversion started by external trigger (hardware starts) |

| CS | A/D Conversion Operation Control |
|----|----------------------------------|
| 0  | Operation stop                   |
| 1  | Operation start                  |

**Notes 1.** Set so that the A/D conversion time is 19.1  $\mu$ s or more.

- **2.** Setting prohibited because A/D conversion time is less than 19.1  $\mu$ s.
- Cautions 1. The following sequence is recommended for power consumption reduction of A/D converter when the standby function is used: Clear bit 7 (CS) to 0 first to stop the A/D conversion operation, and then execute the HALT or STOP instruction.
  - 2. When restarting the stopped A/D conversion operation, start the A/D conversion operation after clearing the interrupt request flag (ADIF) to 0.

Remarks 1. fx : Main system clock oscillation frequency

2. MCS : Oscillation mode selection register (OSMS) bit 0

#### (2) A/D converter input select register (ADIS)

This register determines whether the ANI0/P10 to ANI7/P17 pins should be used for analog input channels or ports. Pins other than those selected as analog input can be used as input/output ports. ADIS is set with an 8-bit memory manipulation instruction. RESET input sets ADIS to 00H.

#### Cautions 1. Set the analog input channel in the following order.

- (1) Set the number of analog input channels with ADIS.
- (2) Using A/D converter mode register (ADM), select one channel to undergo A/D conversion from among the channels set for analog input with ADIS.

Δftor

2. No internal pull-up resistor can be used to the channels set for analog input with ADIS, irrespective of the value of bit 1 (PUO1) of the pull-up resistor option register L (PUOL).

| Symbol | 7     | 6        | 5       | 4     | 3      | 2                  | 1        | 0          | Address        | Reset | R/W |  |  |  |  |  |
|--------|-------|----------|---------|-------|--------|--------------------|----------|------------|----------------|-------|-----|--|--|--|--|--|
| ADIS   | 0     | 0        | 0       | 0     | ADIS3  | ADIS2              | ADIS1    | ADIS0      | FF84H          | 00H   | R/W |  |  |  |  |  |
|        |       |          |         |       |        |                    |          |            |                |       |     |  |  |  |  |  |
|        | ADIS3 | ADIS2    | ADIS1   | ADIS0 | Numb   | per of Ar          | nalog Ir | nput Chai  | nnel Selection |       |     |  |  |  |  |  |
|        | 0     | 0        | 0       | 0     | No an  | nalog inp          | out cha  | nnel (P10  | D-P17)         |       |     |  |  |  |  |  |
|        | 0     | 0        | 0       | 1     | 1 cha  | nnel (Al           | NI0, P1  | 1-P17)     |                |       |     |  |  |  |  |  |
|        | 0     | 0        | 1       | 0     | 2 cha  | nnel (Al           | NIO, AN  | ll1, P12-l | P17)           |       |     |  |  |  |  |  |
|        | 0     | 0        | 1       | 1     | 3 cha  | nnel (Al           | NIO-AN   | I2, P13-F  | P17)           |       |     |  |  |  |  |  |
|        | 0     | 1        | 0       | 0     | 4 cha  | nnel (Al           | NIO-AN   | I3, P14-F  | P17)           |       |     |  |  |  |  |  |
|        | 0     | 1        | 0       | 1     | 5 cha  | nnel (Al           | NIO-AN   | I4, P15-F  | P17)           |       |     |  |  |  |  |  |
|        | 0     | 1        | 1       | 0     | 6 cha  | nnel (Al           | NIO-AN   | I5, P16, I | P17)           |       |     |  |  |  |  |  |
|        | 0     | 1        | 1       | 1     | 7 cha  | nnel (Al           | NIO-AN   | l6, P17)   |                |       |     |  |  |  |  |  |
|        | 1     | 0        | 0       | 0     | 8 cha  | nnel (Al           | NIO-AN   | 17)        |                |       |     |  |  |  |  |  |
|        | 0     | ther tha | an abov | e     | Settin | Setting prohibited |          |            |                |       |     |  |  |  |  |  |

Figure 10-3. A/D Converter Input Select Register Format

#### (3) External interrupt mode register 1 (INTM1)

This register sets the valid edge for INTP3. INTM1 is set with an 8-bit memory manipulation instruction. RESET input sets INTM1 to 00H.

#### After Address 0 R/W Symbol 7 6 5 4 3 2 1 Reset 0 0 0 0 0 0 ES41 ES40 FFEDH 00H INTM1 R/W ES41 ES40 INTP3 Valid Edge Selection 0 0 Falling edge 0 1 Rising edge 1 0 Setting prohibited 1 1 Both falling and rising edges

#### Figure 10-4. External Interrupt Mode Register 1 Format

Caution Set 0 to the bits 2 to 7.

#### 10.4 A/D Converter Operations

#### 10.4.1 Basic operations of A/D converter

- (1) Set the number of analog input channels with A/D converter input select register (ADIS).
- (2) From among the analog input channels set with ADIS, select one channel for A/D conversion with A/D converter mode register (ADM).
- (3) Sample the voltage input to the selected analog input channel with the sample & hold circuit.
- (4) Sampling for the specified period of time sets the sample & hold circuit to the hold state so that the circuit holds the input analog voltage until termination of A/D conversion.
- (5) Bit 7 of the successive approximation register (SAR) is set. The series resistor string voltage tap is set at (1/2) AVREF by the tap selector.
- (6) The voltage difference between the series resistor string voltage tap and the analog input is compared by the voltage comparater. If the analog input is larger than (1/2) AVREF, the MSB of the SAR remains set. If it is smaller than (1/2) AVREF, the MSB is reset.
- (7) Next, bit 6 of SAR is automatically set and the operation proceeds to the next comparison. In this case, the series resistor string voltage tap is selected according to the preset value of bit 7 as described below.
  - Bit 7 = 1 : (3/4) AVREF
  - Bit 7 = 0 : (1/4) AVREF

The voltage tap and analog input voltage are compared and bit 6 of SAR is manipulated with the result as follows.

- Analog input voltage  $\geq$  Voltage tap : Bit 6 = 1
- Analog input voltage  $\leq$  Voltage tap : Bit 6 = 0
- (8) Comparison of this sort continues up to bit 0 of SAR.
- (9) Upon completion of the comparison of 8 bits, any effective digital resultant value remains in SAR and the resultant value is transferred to and latched in the A/D conversion result register (ADCR).

At the same time, the A/D conversion termination interrupt request (INTAD) can also be generated.

#### Figure 10-5. A/D Converter Basic Operation



A/D conversion operations are performed continuously until bit 7 (CS) of A/D converter mode register (ADM) is reset (0) by software.

If a write to the ADM is performed during an A/D conversion operation, the conversion operation is initialized, and if the CS bit is set (1), conversion starts again from the beginning.

After RESET input, the value of ADCR is undefined.

#### 10.4.2 Input voltage and conversion results

The relation between the analog input voltage input to the analog input pins (ANI0 to ANI7) and the A/D conversion result (the value stored in A/D conversion result register (ADCR)) is shown by the following expression.

ADCR = INT (
$$\frac{V_{\text{IN}}}{\text{AV}_{\text{REF}}} \times 256$$
 + 0.5)

or

$$(\text{ADCR} - 0.5) \times \frac{\text{AV}_{\text{REF}}}{256} \le \text{V}_{\text{IN}} < (\text{ADCR} + 0.5) \times \frac{\text{AV}_{\text{REF}}}{256}$$

Where, INT() : Function which returns integer parts of value in parentheses.

VIN : Analog input voltage

AVREF : AVREF pin voltage

ADCR : Value of A/D conversion result register (ADCR)

Figure 10-6 shows the relation between the analog input voltage and the A/D conversion result.





#### 10.4.3 A/D converter operating mode

Using the A/D converter input select register (ADIS) and the A/D converter mode register (ADM), select one channel for the analog input from ANI0 to ANI7 and start A/D conversion.

The following two ways are available to start A/D conversion.

- Hardware start: Conversion is started by trigger input (INTP3).
- Software start: Conversion is started by setting ADM.

The A/D conversion result is stored in the A/D conversion result register (ADCR) and the interrupt request signal (INTAD) is simultaneously generated.

#### (1) A/D conversion by hardware start

When bit 6 (TRG) and bit 7 (CS) of A/D converter mode register (ADM) are set to 1, the A/D conversion standby state is set. When the external trigger signal (INTP3) is input, the A/D conversion starts on the voltage applied to the analog input pins specified with bits 1 to 3 (ADM1 to ADM3) of ADM.

Upon termination of the A/D conversion, the conversion result is stored in the A/D conversion result register (ADCR) and the interrupt request signal (INTAD) is generated. After one A/D conversion operation is started and terminated, another operation is not started until a new external trigger signal is input.

If data with CS set to 1 is written to ADM again during A/D conversion, the converter suspends its A/D conversion operation and waits for a new external trigger signal to be input. When the external trigger input signal is reinput, A/D conversion is carried out from the beginning.

If data with CS set to 0 is written to ADM during A/D conversion, the A/D conversion operation stops immediately.





**Remarks 1.** n = 0, 1, ..., 7 **2.** m = 0, 1, ..., 7

#### (2) A/D conversion operation in software start

When bit 6 (TRG) and bit 7 (CS) of A/D converter mode register (ADM) are set to 0 and 1, respectively, the A/D conversion starts on the voltage applied to the analog input pins specified with bits 1 to 3 (ADM1 to ADM3) of ADM.

Upon termination of the A/D conversion, the conversion result is stored in the A/D conversion result register (ADCR) and the interrupt request signal (INTAD) is generated. After one A/D conversion operation is started and terminated, the next A/D conversion operation starts immediately. The A/D conversion operation continues repeatedly until new data is written to ADM.

If data with CS set to 1 is written to ADM again during A/D conversion, the converter suspends its A/D conversion operation and starts A/D conversion on the newly written data.

If data with CS set to 0 is written to ADM during A/D conversion, the A/D conversion operation stops immediately.



Figure 10-8. A/D Conversion by Software Start

**Remarks 1.** n = 0, 1, ..., 7 **2.** m = 0, 1, ..., 7

#### 10.5 A/D Converter Cautions

#### (1) Power consumption in standby mode

The A/D converter operates on the main system clock. Therefore, its operation stops in STOP mode. As a current still flows in the AV<sub>REF</sub> pin at this time, this current must be cut in order to minimize the overall system power dissipation. In Figure 10-9, the power dissipation can be reduced by outputting a low-level signal to the output port in standby mode. However, there is no precision to the actual AV<sub>REF</sub> voltage, and therefore the conversion values themselves lack precision and can only be used for relative comparison.

Figure 10-9. Example of Method of Reducing Current Dissipation in Standby Mode



#### (2) Input range of ANI0 to ANI7

The input voltages of ANI0 to ANI7 should be within the specification range. In particular, if a voltage above AVREF or below AVss is input (even if within the absolute maximum rating range), the conversion value for that channel will be indeterminate. The conversion values of the other channels may also be affected.

#### (3) Noise countermeasures

In order to maintain 8-bit resolution, attention must be paid to noise on pins AVREF and ANI0 to ANI7. Since the effect increases in proportion to the output impedance of the analog input source, it is recommended that a capacitor be connected externally as shown in Figure 10-10 in order to reduce noise.



#### Figure 10-10. Analog Input Pin Disposition

#### (4) Pins ANI0/P10 to ANI7/P17

The analog input pins ANI0 to ANI7 also function as input/output port (PORT1) pins. When A/D conversion is performed with any of pins ANI0 to ANI7 selected, be sure not to execute a PORT1 input instruction while conversion is in progress, as this may reduce the conversion resolution.

Also, if digital pulses are applied to a pin adjacent to the pin in the process of A/D conversion, the expected A/D conversion value may not be obtainable due to coupling noise. Therefore, avoid applying pulses to pins adjacent to the pin undergoing A/D conversion.

#### (5) AVREF pin input impedance

A series resistor string of approximately 10 k $\Omega$  is connected between the AV<sub>REF</sub> pin and the AV<sub>SS</sub> pin. Therefore, if the output impedance of the reference voltage source is high, this will result in parallel connection to the series resistor string between the AV<sub>REF</sub> pin and the AV<sub>SS</sub> pin, and there will be a large reference voltage error.

#### (6) Interrupt request flag (ADIF)

The interrupt request flag (ADIF) is not cleared even if the A/D converter mode register (ADM) is changed. Caution is therefore required since, if a change of analog input pin is performed during A/D conversion, the A/D conversion result and ADIF for the pre-change analog input may be set just before the ADM rewrite, and when ADIF is read immediately after the ADM rewrite, ADIF may be set despite the fact that the A/D conversion for the post-change analog input has not ended.

When the A/D conversion is stopped and then resumed, clear the ADIF before it is resumed.





#### (7) AVDD pin

The AV<sub>DD</sub> pin is the analog circuit power supply pin, and supplies power to the input circuits of ANI0/P10 to ANI7/P17.

Therefore, be sure to apply the same voltage as V<sub>DD</sub> to this pin shown in the following figure even when the application circuit is designed so as to switch to a backup battery.



#### Figure 10-12. Handling of AVDD Pin

[MEMO]

#### CHAPTER 11 SERIAL INTERFACE CHANNEL 2

#### 11.1 Serial Interface Channel 2 Functions

Serial interface channel 2 has the following three modes.

- · Operation stop mode
- Asynchronous serial interface (UART) mode
- 3-wire serial I/O mode

#### (1) Operation stop mode

This mode is used when serial transfer is not carried out to reduce power consumption.

#### (2) Asynchronous serial interface (UART) mode

In this mode, one byte of data is transmitted/received following the start bit, and full-duplex operation is possible.

A dedicated UART baud rate generator is incorporated, allowing communication over a wide range of baud rates. In addition, the baud rate can be defined by scaling the input clock to the ASCK pin.

The MIDI standard baud rate (31.25 kbps) can be used by employing the dedicated UART baud rate generator.

#### (3) 3-wire serial I/O mode (MSB-first/LSB-first switchable)

In this mode, 8-bit data transfer is performed using three lines: the serial clock (SCK2), and serial data lines (SI2, SO2).

In the 3-wire serial I/O mode, simultaneous transmission and reception is possible, increasing the data transfer processing speed.

Either the MSB or LSB can be specified as the start bit for an 8-bit data serial transfer, allowing connection to devices using either as the start bit.

The 3-wire serial I/O mode is useful for connection to peripheral I/Os and display controllers, etc., which incorporate a conventional synchronous clocked serial interface, such as the 75X/XL series, 78K series, 17K series, etc.

### 11.2 Serial Interface Channel 2 Configuration

Serial interface channel 2 consists of the following hardware.

| Table 11-1. | Serial Interface | Channel 2 | Configuration |
|-------------|------------------|-----------|---------------|
|             |                  |           | ooningaration |

| Item             | Configuration                                                                                                                                                                                         |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register         | Transmit shift register (TXS)<br>Receive shift register (RXS)<br>Receive buffer register (RXB)                                                                                                        |
| Control register | Serial operating mode register 2 (CSIM2)<br>Asynchronous serial interface mode register (ASIM)<br>Asynchronous serial interface status register (ASIS)<br>Baud rate generator control register (BRGC) |



Figure 11-1. Serial Interface Channel 2 Block Diagram

\*

**Note** See Figure 11-2 for the baud rate generator configuration.



#### Figure 11-2. Baud Rate Generator Block Diagram

#### (1) Transmit shift register (TXS)

This register is used to set the transmit data. The data written in TXS is transmitted as serial data. If the data length is specified as 7 bits, bits 0 to 6 of the data written in TXS are transferred as transmit data. Writing data to TXS starts the transmit operation.

TXS is written to with an 8-bit memory manipulation instruction. It cannot be read.

TXS value is FFH after RESET input.

# Caution TXS must not be written to during a transmit operation. TXS and the receive buffer register (RXB) are allocated to the same address, and when a read is performed, the value of RXB is read.

#### (2) Receive shift register (RXS)

This register is used to convert serial data input to the RxD pin to parallel data. When one byte of data is received, the receive data is transferred to the receive buffer register (RXB). RXS cannot be directly manipulated by a program.

#### (3) Receive buffer register (RXB)

This register holds receive data. Each time one byte of data is received, new receive data is transferred from the receive shift register (RXS).

If the data length is specified as 7 bits, the receive data is transferred to bits 0 to 6 of RXB, and the MSB of RXB is always set to 0.

RXB is read with an 8-bit memory manipulation instruction. It cannot be written to. RXB value is FFH after RESET input.

### Caution RXB and the transmit shift register (TXS) are allocated to the same address, and when a write is performed, the value is written to TXS.

#### (4) Transmission control circuit

This circuit performs transmit operation control such as the addition of a start bit, parity bit and stop bit to data written in the transmit shift register (TXS) in accordance with the contents set in the asynchronous serial interface mode register (ASIM).

#### (5) Reception control circuit

This circuit controls receive operations in accordance with the contents set in the asynchronous serial interface mode register (ASIM). It performs error checks for parity errors, etc., during a receive operation, and if an error is detected, sets a value in the asynchronous serial interface status register (ASIS) in accordance with the error contents.

#### 11.3 Serial Interface Channel 2 Control Registers

Serial interface channel 2 is controlled by the following four registers.

- Serial Operating Mode Register 2 (CSIM2)
- Asynchronous Serial Interface Mode Register (ASIM)
- Asynchronous Serial Interface Status Register (ASIS)
- Baud Rate Generator Control Register (BRGC)
- (1) Serial operating mode register 2 (CSIM2)

This register is set when serial interface channel 2 is used in the 3-wire serial I/O mode. CSIM2 is set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets CSIM2 to 00H.



#### Figure 11-3. Serial Operating Mode Register 2 Format

Cautions 1. Set 0 to the bits 0 and 3 to 6.

2. When UART mode is selected, CSIM2 should be set to 00H.

#### (2) Asynchronous serial interface mode register (ASIM)

This register is set when serial interface channel 2 is used in the asynchronous serial interface mode. ASIM is set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets ASIM to 00H.





Note When SCK is set to 1 and the baud rate generator output is selected, the ASCK pin can be used as an input/output port.

- Cautions 1. When the 3-wire serial I/O mode is selected, 00H should be set in ASIM.
  - 2. The serial transmit/receive operation must be stopped before changing the operating mode.

#### Table 11-2. Serial Interface Channel 2 Operating Mode Settings

#### (1) Operation Stop Mode

| Å   | ASIM             |     | CSIM2 |        |      | PM70               | P70                | PM71               | P71                | PM72               | P72                |     | Shift |             |                       | P72/SCK2               |
|-----|------------------|-----|-------|--------|------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|-----|-------|-------------|-----------------------|------------------------|
| TXE | RXE              | SCK | CSIE2 | CSIM22 | CSCK |                    |                    |                    |                    |                    |                    | Bit | Clock |             | /TxD Pin<br>Functions | /ASCK Pin<br>Functions |
| 0   | 0                | х   | 0     | х      | х    | X <sup>Note1</sup> | _   | _     | P70         | P71                   | P72                    |
|     | Other than above |     |       |        |      |                    |                    |                    |                    |                    |                    |     |       | Setting pro | phibited              |                        |

#### (2) 3-wire Serial I/O Mode

|     | SIM              |     | CSIM2 |        |      | PM70               | P70                | PM71 | P71 | PM72 | P72 | Start<br>Bit | Shift<br>Clock    | P70/SI2<br>/RxD Pin  | P71/SO2<br>/TxD Pin     | P72/SCK2<br>/ASCK Pin |
|-----|------------------|-----|-------|--------|------|--------------------|--------------------|------|-----|------|-----|--------------|-------------------|----------------------|-------------------------|-----------------------|
| TXE | RXE              | SCK | CSIE2 | CSIM22 | CSCK |                    |                    |      |     |      |     |              |                   | Functions            | Functions               | Functions             |
| 0   | 0                | 0   | 1     | 0      | 0    | 1 <sup>Note2</sup> | X <sup>Note2</sup> | 0    | 1   | 1    | х   | MSB          | External<br>clock | SI2 <sup>Note2</sup> | SO2<br>(CMOS<br>output) | SCK2 input            |
|     |                  |     |       |        | 1    |                    |                    |      |     | 0    | 1   |              | Internal<br>clock |                      |                         | SCK2 output           |
|     |                  |     | 1     | 1      | 0    |                    |                    |      |     | 1    | х   | LSB          | External clock    |                      |                         | SCK2 input            |
|     |                  |     |       |        | 1    |                    |                    |      |     | 0    | 1   |              | Internal<br>clock |                      |                         | SCK2 output           |
|     | Other than above |     |       |        |      |                    |                    |      |     |      |     |              |                   | Setting p            | rohibited               |                       |

#### (3) Asynchronous Serial Interface Mode

| A   | SIM              |     |       | CSIM2  |      | PM70               | P70                | PM71               | P71     | PM72    | P72     | Start              | Shift             | P70/SI2               | P71/SO2                 | P72/SCK2               |
|-----|------------------|-----|-------|--------|------|--------------------|--------------------|--------------------|---------|---------|---------|--------------------|-------------------|-----------------------|-------------------------|------------------------|
| TXE | RXE              | SCK | CSIE2 | CSIM22 | CSCK |                    |                    |                    |         |         |         | Bit                | Clock             | /RxD Pin<br>Functions | /TxD Pin<br>Functions   | /ASCK Pin<br>Functions |
| 1   | 0                | 0   | 0     | 0      | 0    | X <sup>Note1</sup> | X <sup>Note1</sup> | 0                  | 1       | 1       | х       | LSB                | External<br>clock | P70                   | TxD<br>(CMOS<br>output) | ASCK input             |
|     |                  | 1   |       |        |      |                    |                    |                    |         | X Note1 | X Note1 |                    | Internal<br>clock |                       | . ,                     | P72                    |
| 0   | 1                | 0   | 0     | 0      | 0    | 1                  | х                  | X <sup>Note1</sup> | X Note1 | 1       | х       |                    | External<br>clock | RxD                   | P71                     | ASCK input             |
|     |                  | 1   |       |        |      |                    |                    |                    |         | X Note1 | X Note1 |                    | Internal<br>clock |                       |                         | P72                    |
| 1   | 1                | 0   | 0     | 0      | 0    | 1                  | х                  | 0                  | 1       | 1       | х       |                    | External<br>clock |                       | TxD<br>(CMOS<br>output) | ASCK input             |
|     |                  | 1   |       |        |      |                    |                    |                    |         | X Note1 | X Note1 |                    | Internal<br>clock |                       |                         | P72                    |
|     | Other than above |     |       |        |      |                    |                    |                    |         |         |         | Setting prohibited |                   |                       |                         |                        |

**Notes 1.** Can be used freely as port function.

2. Can be used as P70 (CMOS input/output) when only transmitter is used.

Remark × : Don't care

 $PM \times \times$ : Port mode register  $P \times \times$ : Port output latch

#### (3) Asynchronous serial interface status register (ASIS)

This is a register which displays the type of error when a reception error is generated in the asynchronous serial interface mode.

ASIS is read with a 1-bit or 8-bit memory manipulation instruction.

In 3-wire serial I/O mode, the contents of the ASIS are undefined.

RESET input sets ASIS to 00H.





- **Notes 1.** The receive buffer register (RXB) must be read when an overrun error is generated. Overrun errors will continue to be generated until RXB is read.
  - **2.** Even if the stop bit length has been set as 2 bits by bit 2 (SL) of the asynchronous serial interface mode register (ASIM), only single stop bit detection is performed during reception.

#### (4) Baud rate generator control register (BRGC)

This register sets the serial clock for serial interface channel 2. BRGC is set with an 8-bit memory manipulation instruction. RESET input sets BRGC to 00H.

#### Figure 11-6. Baud Rate Generator Control Register Format (1/2)

| Symbol | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | Address | After Reset | R/W |
|--------|------|------|------|------|------|------|------|------|---------|-------------|-----|
| BRGC   | TPS3 | TPS2 | TPS1 | TPS0 | MDL3 | MDL2 | MDL1 | MDL0 | FF73H   | 00H         | R/W |

| MDL3 | MDL2 | MDL1 | MDL0 | Baud Rate Generator Input Clock Selection | k  |
|------|------|------|------|-------------------------------------------|----|
| 0    | 0    | 0    | 0    | fscк/16                                   | 0  |
| 0    | 0    | 0    | 1    | fscк/17                                   | 1  |
| 0    | 0    | 1    | 0    | fscк/18                                   | 2  |
| 0    | 0    | 1    | 1    | fscк/19                                   | 3  |
| 0    | 1    | 0    | 0    | fscк/20                                   | 4  |
| 0    | 1    | 0    | 1    | fscк/21                                   | 5  |
| 0    | 1    | 1    | 0    | fsck/22                                   | 6  |
| 0    | 1    | 1    | 1    | fsck/23                                   | 7  |
| 1    | 0    | 0    | 0    | fsck/24                                   | 8  |
| 1    | 0    | 0    | 1    | fscк/25                                   | 9  |
| 1    | 0    | 1    | 0    | fsck/26                                   | 10 |
| 1    | 0    | 1    | 1    | fscк/27                                   | 11 |
| 1    | 1    | 0    | 0    | fsck/28                                   | 12 |
| 1    | 1    | 0    | 1    | fsck/29                                   | 13 |
| 1    | 1    | 1    | 0    | fsck/30                                   | 14 |
| 1    | 1    | 1    | 1    | f <sub>SCK</sub> Note                     | _  |

Note Can only be used in 3-wire serial I/O mode.

Remarks 1. fsck : 5-bit counter source clock

**2.** k : Value set in MDL0 to MDL3 ( $0 \le k \le 14$ )

| TPS3  | TPS2   | TPS1 | TPS0 |                     | 5-Bit Cou           | 5-Bit Counter Source Clock Selection |                    |            |    |  |  |  |
|-------|--------|------|------|---------------------|---------------------|--------------------------------------|--------------------|------------|----|--|--|--|
|       | 11 02  |      |      |                     | MCS=1               |                                      | MCS=0              |            | n  |  |  |  |
| 0     | 0      | 0    | 0    | fxx/2 <sup>10</sup> | fxx/2 <sup>10</sup> | (4.9 kHz)                            | fx/2 <sup>11</sup> | (2.4 kHz)  | 11 |  |  |  |
| 0     | 1      | 0    | 1    | fxx                 | fx                  | (5.0 MHz)                            | fx/2               | (2.5 MHz)  | 1  |  |  |  |
| 0     | 1      | 1    | 0    | fxx/2               | fx/2                | (2.5 MHz)                            | fx/2 <sup>2</sup>  | (1.25 MHz) | 2  |  |  |  |
| 0     | 1      | 1    | 1    | fxx/2 <sup>2</sup>  | fx/2 <sup>2</sup>   | (1.25 MHz)                           | fx/2 <sup>3</sup>  | (625 kHz)  | 3  |  |  |  |
| 1     | 0      | 0    | 0    | fxx/2 <sup>3</sup>  | fx/2 <sup>3</sup>   | (625 kHz)                            | fx/2 <sup>4</sup>  | (313 kHz)  | 4  |  |  |  |
| 1     | 0      | 0    | 1    | fxx/2 <sup>4</sup>  | fx/2 <sup>4</sup>   | (313 kHz)                            | fx/2 <sup>5</sup>  | (156 kHz)  | 5  |  |  |  |
| 1     | 0      | 1    | 0    | fxx/2 <sup>5</sup>  | fx/2 <sup>5</sup>   | (156 kHz)                            | fx/2 <sup>6</sup>  | (78.1 kHz) | 6  |  |  |  |
| 1     | 0      | 1    | 1    | fxx/2 <sup>6</sup>  | fx/2 <sup>6</sup>   | (78.1 kHz)                           | fx/2 <sup>7</sup>  | (39.1 kHz) | 7  |  |  |  |
| 1     | 1      | 0    | 0    | fxx/2 <sup>7</sup>  | fx/2 <sup>7</sup>   | (39.1 kHz)                           | fx/2 <sup>8</sup>  | (19.5 kHz) | 8  |  |  |  |
| 1     | 1      | 0    | 1    | fxx/2 <sup>8</sup>  | fx/2 <sup>8</sup>   | (19.5 kHz)                           | fx/2 <sup>9</sup>  | (9.8 kHz)  | 9  |  |  |  |
| 1     | 1      | 1    | 0    | fxx/2 <sup>9</sup>  | fx/2 <sup>9</sup>   | (9.8 kHz)                            | fx/2 <sup>10</sup> | (4.9 kHz)  | 10 |  |  |  |
| Other | than a | bove |      | Setting proh        | ibited              | Setting prohibited                   |                    |            |    |  |  |  |

Figure 11-6. Baud Rate Generator Control Register Format (2/2)

# Caution When a write is performed to BRGC during a communication operation, baud rate generator output is disrupted and communication cannot be performed normally. Therefore, BRGC must not be written to during a communication operation.

- **Remarks 1.** fx : Main system clock oscillation frequency
  - **2.** fxx : Main system clock frequency (fx or fx/2)
  - 3. MCS : Oscillation mode selection register (OSMS) bit 0
  - 4. n : Value set in TPS0 to TPS3 (1  $\leq$  n  $\leq$  11)
  - 5. Values in parentheses when operated at fx=5.0 MHz

The baud rate transmit/receive clock generated is either a signal scaled from the main system clock, or a signal scaled from the clock input from the ASCK pin.

#### (a) Generation of baud rate transmit/receive clock by means of main system clock

The transmit/receive clocks generated by scaling the main system clock. The baud rate generated from the main system clock is found from the following expression.

[Baud rate] =  $\frac{f_{XX}}{2^n \times (k+16)}$  [Hz]

fx

where,

: Main system clock oscillation frequency

fxx : Main system clock frequency (fx or fx/2)

- n : Value set in TPS0 to TPS3 ( $1 \le n \le 11$ )
- k : Value set in MDL0 to MDL3 (0  $\leq$  k  $\leq$  14)

| Baud  |                | fx=5.0    | MHz            |           |                | fx=4.1    | 9 MHz          |           |
|-------|----------------|-----------|----------------|-----------|----------------|-----------|----------------|-----------|
| Rate  | MCS=1          |           | MCS=0          | )         | MCS=1          |           | MCS=0          |           |
| (bps) | BRGC Set Value | Error (%) |
| 75    | -              |           | 00H            | 1.73      | 0BH            | 1.14      | EBH            | 1.14      |
| 110   | 06H            | 0.88      | E6H            | 0.88      | 03H            | -2.01     | E3H            | -2.01     |
| 150   | 00H            | 1.73      | E0H            | 1.73      | EBH            | 1.14      | DBH            | 1.14      |
| 300   | E0H            | 1.73      | D0H            | 1.73      | DBH            | 1.14      | СВН            | 1.14      |
| 600   | D0H            | 1.73      | СОН            | 1.73      | СВН            | 1.14      | BBH            | 1.14      |
| 1200  | СОН            | 1.73      | B0H            | 1.73      | BBH            | 1.14      | ABH            | 1.14      |
| 2400  | B0H            | 1.73      | A0H            | 1.73      | ABH            | 1.14      | 9BH            | 1.14      |
| 4800  | A0H            | 1.73      | 90H            | 1.73      | 9BH            | 1.14      | 8BH            | 1.14      |
| 9600  | 90H            | 1.73      | 80H            | 1.73      | 8BH            | 1.14      | 7BH            | 1.14      |
| 19200 | 80H            | 1.73      | 70H            | 1.73      | 7BH            | 1.14      | 6BH            | 1.14      |
| 31250 | 74H            | 0         | 64H            | 0         | 71H            | -1.31     | 61H            | -1.31     |
| 38400 | 70H            | 1.73      | 60H            | 1.73      | 6BH            | 1.14      | 5BH            | 1.14      |
| 76800 | 60H            | 1.73      | 50H            | 1.73      | 5BH            | 1.14      | _              | _         |

#### Table 11-3. Relation between Main System Clock and Baud Rate

Remark MCS: Oscillation mode selection register (OSMS) bit 0

(b) Generation of baud rate transmit/receive clock by means of external clock from ASCK pin The transmit/receive clock is generated by scaling the clock input from the ASCK pin. The baud rate generated from the clock input from the ASCK pin is obtained with the following expression.

[Baud rate] = 
$$\frac{f_{ASCK}}{2 \times (k+16)}$$
 [Hz]

where,  $\begin{array}{rcl} f_{ASCK} & : & \mbox{Frequency of clock input to ASCK pin} \\ k & : & \mbox{Value set in MDL0 to MDL3 } (0 \leq k \leq 14) \end{array}$ 

#### Table 11-4. Relation between ASCK Pin Input Frequency and Baud Rate (When BRGC is set to 00H)

| Baud Rate (bps) | ASCK Pin Input Frequency |
|-----------------|--------------------------|
| 75              | 2.4 kHz                  |
| 110             | 3.52 kHz                 |
| 150             | 4.8 kHz                  |
| 300             | 9.6 kHz                  |
| 600             | 19.2 kHz                 |
| 1200            | 38.4 kHz                 |
| 2400            | 76.8 kHz                 |
| 4800            | 153.6 kHz                |
| 9600            | 307.2 kHz                |
| 19200           | 614.4 kHz                |
| 31250           | 1000.0 kHz               |
| 38400           | 1228.8 kHz               |

#### 11.4 Serial Interface Channel 2 Operation

Serial interface channel 2 has the following three modes.

- Operation stop mode
- Asynchronous serial interface (UART) mode
- 3-wire serial I/O mode

#### 11.4.1 Operation stop mode

In the operation stop mode, serial transfer is not performed, and therefore power consumption can be reduced. In the operation stop mode, the P70/SI2/RxD, P71/SO2/TxD and P72/SCK2/ASCK pins can be used as normal input/output ports.

#### (1) Register setting

Operation stop mode settings are performed using serial operating mode register 2 (CSIM2) and the asynchronous serial interface mode register (ASIM).

#### (a) Serial operating mode register 2 (CSIM2)

 $\frac{\text{CSIM2}}{\text{RESET}} \text{ is set with a 1-bit or 8-bit memory manipulation instruction.} \\ \overrightarrow{\text{RESET}} \text{ input sets CSIM2 to 00H.}$ 

| Symbol | $\overline{O}$ | 6 | 5 | 4 | 3 | 2          | 1    | 0 | Addr  | ess | After Reset     | R/W                       |   |
|--------|----------------|---|---|---|---|------------|------|---|-------|-----|-----------------|---------------------------|---|
| CSIM2  | CSIE2          | 0 | 0 | 0 | 0 | CSIM<br>22 | CSCK | 0 | FF72  | 2H  | 00H             | R/W                       |   |
|        |                |   |   |   |   |            |      |   | _     |     |                 |                           |   |
|        |                |   |   |   |   |            |      |   | CSIE2 | Ope | eration Control | in 3-wire Serial I/O Mode |   |
|        |                |   |   |   |   |            |      |   | 0     | Ope | eration stopped | t                         |   |
|        |                |   |   |   |   |            |      |   | 1     | Ope | eration enabled | t                         | - |

Caution Set 0 to the bits 0 and 3 to 6.

#### (b) Asynchronous serial interface mode register (ASIM)

 $\ensuremath{\mathsf{ASIM}}$  is set with a 1-bit or 8-bit memory manipulation instruction.  $\ensuremath{\overline{\mathsf{RESET}}}$  input sets ASIM to 00H.



#### 11.4.2 Asynchronous serial interface (UART) mode

In this mode, one byte of data is transmitted/received following the start bit, and full-duplex operation is possible. A dedicated UART baud rate generator is incorporated, allowing communication over a wide range of baud rates. In addition, the baud rate can be defined by scaling the input clock to the ASCK pin.

The MIDI standard baud rate (31.25 kbps) can be used by employing the dedicated UART baud rate generator.

#### (1) Register setting

UART mode settings are performed using serial operating mode register 2 (CSIM2), the asynchronous serial interface mode register (ASIM), the asynchronous serial interface status register (ASIS), and the baud rate generator control register (BRGC).

#### (a) Serial operating mode register 2 (CSIM2)

CSIM2 is set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets CSIM2 to 00H. When the UART mode is selected, 00H should be set in CSIM2.



Caution Set 0 to the bits 0 and 3 to 6.

#### (b) Asynchronous serial interface mode register (ASIM)

ASIM is set with a 1-bit or 8-bit memory manipulation instruction.  $$\overline{\sf RESET}$$  input sets ASIM to 00H.

| Symbol | $\overline{\mathcal{O}}$ | 6   | 5   | 4   | 3  | 2  | 1    | 0   | Addr     | ess A         | After Reset                   | R/W                                                                   |
|--------|--------------------------|-----|-----|-----|----|----|------|-----|----------|---------------|-------------------------------|-----------------------------------------------------------------------|
| ASIM   | TXE                      | RXE | PS1 | PS0 | CL | SL | ISRM | SCK | FF70     | H             | 00H                           | R/W                                                                   |
| ·      |                          |     |     |     |    |    |      |     |          |               |                               |                                                                       |
|        |                          |     |     |     |    |    |      |     | SCK      | Clock<br>Mode |                               | Asynchronous Serial Interface                                         |
|        |                          |     |     |     |    |    |      |     | 0        | Input         | clock from of                 | f-chip to ASCK pin                                                    |
|        |                          |     |     |     |    |    |      |     | 1        | Dedic         | ated baud ra                  | te generator output <sup>Note</sup>                                   |
|        |                          |     |     |     |    |    |      |     |          |               |                               |                                                                       |
|        |                          |     |     |     |    |    |      |     | ISRM     |               | ol of Recepti<br>or Generatio | on Completion Interrupt in Case<br>n                                  |
|        |                          |     |     |     |    |    |      |     | 0        |               | otion comple<br>e of error ge | tion interrupt request generated neration                             |
|        |                          |     |     |     |    |    |      |     | 1        |               |                               | tion interrupt request not of error generation                        |
|        |                          |     |     |     |    |    |      |     |          |               |                               |                                                                       |
|        |                          |     |     |     |    |    |      |     | SL       | Trans         | mit Data Sto                  | p Bit Length Specification                                            |
|        |                          |     |     |     |    |    |      |     | 0        | 1 bit         |                               |                                                                       |
|        |                          |     |     |     |    |    |      |     | 1        | 2 bits        |                               |                                                                       |
|        |                          |     |     |     |    |    |      |     |          |               |                               |                                                                       |
|        |                          |     |     |     |    |    |      |     | CL       | Chara         | cter Length                   | Specification                                                         |
|        |                          |     |     |     |    |    |      |     | 0        | 7 bits        |                               |                                                                       |
|        |                          |     |     |     |    |    |      |     | 1        | 8 bits        |                               |                                                                       |
|        |                          |     |     |     |    |    |      |     |          |               |                               |                                                                       |
|        |                          |     |     |     |    |    |      |     | PS1      | PS0           |                               | Specification                                                         |
|        |                          |     |     |     |    |    |      |     | 0        | 0             | No Parity                     |                                                                       |
|        |                          |     |     |     |    |    |      |     | 0        | 1             |                               | vays added in transmission<br>est in reception (parity error not<br>) |
|        |                          |     |     |     |    |    |      |     | 1        | 0             | Odd parity                    |                                                                       |
|        |                          |     |     |     |    |    |      |     | 1        | 1             | Even parit                    | у                                                                     |
|        |                          |     |     |     |    |    |      |     |          |               |                               |                                                                       |
|        |                          |     |     |     |    |    |      |     | RXE      | Recei         | ve Operatior                  | Control                                                               |
|        |                          |     |     |     |    |    |      |     | 0        | Recei         | ve operation                  | stopped                                                               |
|        |                          |     |     |     |    |    |      |     | 1        | Recei         | ve operation                  | enabled                                                               |
|        |                          |     |     |     |    |    |      |     | <b>r</b> |               |                               |                                                                       |
|        |                          |     |     |     |    |    |      |     | TXE      |               | mit Operatio                  |                                                                       |
|        |                          |     |     |     |    |    |      |     | 0        |               | mit operatior                 |                                                                       |
|        |                          |     |     |     |    |    |      |     | 1        | Trans         | mit operatior                 | n enabled                                                             |

- **Note** When SCK is set to 1 and the baud rate generator output is selected, the ASCK pin can be used as an input/output port.
- Caution The serial transmit/receive operation must be stopped before changing the operating mode.

#### (c) Asynchronous serial interface status register (ASIS)

ASIS is set with a 1-bit or 8-bit memory manipulation instruction. RESET input sets ASIS to 00H.



- **Notes 1.** The receive buffer register (RXB) must be read when an overrun error is generated. Overrun errors will continue to be generated until RXB is read.
  - **2.** Even if the stop bit length has been set as 2 bits by bit 2 (SL) of the asynchronous serial interface mode register (ASIM), only single stop bit detection is performed during reception.

#### (d) Baud rate generator control register (BRGC)

 $\frac{\mathsf{BRGC} \text{ is set with an 8-bit memory manipulation instruction.}}{\mathsf{RESET}}$  input sets BRGC to 00H.

| Symbol | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | Address | After Reset | R/W |
|--------|------|------|------|------|------|------|------|------|---------|-------------|-----|
| BRGC   | TPS3 | TPS2 | TPS1 | TPS0 | MDL3 | MDL2 | MDL1 | MDL0 | FF73H   | 00H         | R/W |

| MDL3 | MDL2 | MDL1 | MDL0 | Baud Rate Generator Input Clock Selection | k  |
|------|------|------|------|-------------------------------------------|----|
| 0    | 0    | 0    | 0    | fsck/16                                   | 0  |
| 0    | 0    | 0    | 1    | fscк/17                                   | 1  |
| 0    | 0    | 1    | 0    | fsck/18                                   | 2  |
| 0    | 0    | 1    | 1    | fsck/19                                   | 3  |
| 0    | 1    | 0    | 0    | fscк/20                                   | 4  |
| 0    | 1    | 0    | 1    | fscк/21                                   | 5  |
| 0    | 1    | 1    | 0    | fsck/22                                   | 6  |
| 0    | 1    | 1    | 1    | fsck/23                                   | 7  |
| 1    | 0    | 0    | 0    | fscк/24                                   | 8  |
| 1    | 0    | 0    | 1    | fsck/25                                   | 9  |
| 1    | 0    | 1    | 0    | fsck/26                                   | 10 |
| 1    | 0    | 1    | 1    | fsck/27                                   | 11 |
| 1    | 1    | 0    | 0    | fscк/28                                   | 12 |
| 1    | 1    | 0    | 1    | fscк/29                                   | 13 |
| 1    | 1    | 1    | 0    | fscк/30                                   | 14 |

(continued)

Remark

fsck : 5-bit counter source clock

k : Value set in MDL0 to MDL3 ( $0 \le k \le 14$ )

| TPS3  | TPS2   | TPS1  | TPS0  |                     | 5-Bit Cou          | 5-Bit Counter Source Clock Selection |                    |            |    |  |  |
|-------|--------|-------|-------|---------------------|--------------------|--------------------------------------|--------------------|------------|----|--|--|
|       | 11 02  | 11 01 | 11 00 |                     | MCS=1              |                                      | MCS=0              |            | n  |  |  |
| 0     | 0      | 0     | 0     | fxx/2 <sup>10</sup> | fx/2 <sup>10</sup> | (4.9 kHz)                            | fx/2 <sup>11</sup> | (2.4 kHz)  | 11 |  |  |
| 0     | 1      | 0     | 1     | fxx                 | fx                 | (5.0 MHz)                            | fx/2               | (2.5 MHz)  | 1  |  |  |
| 0     | 1      | 1     | 0     | fxx/2               | fx/2               | (2.5 MHz)                            | fx/2 <sup>2</sup>  | (1.25 MHz) | 2  |  |  |
| 0     | 1      | 1     | 1     | fxx/2 <sup>2</sup>  | fx/2 <sup>2</sup>  | (1.25 MHz)                           | fx/2 <sup>3</sup>  | (625 kHz)  | 3  |  |  |
| 1     | 0      | 0     | 0     | fxx/2 <sup>3</sup>  | fx/2 <sup>3</sup>  | (625 kHz)                            | fx/2 <sup>4</sup>  | (313 kHz)  | 4  |  |  |
| 1     | 0      | 0     | 1     | fxx/2 <sup>4</sup>  | fx/2 <sup>4</sup>  | (313 kHz)                            | fx/2 <sup>5</sup>  | (156 kHz)  | 5  |  |  |
| 1     | 0      | 1     | 0     | fxx/2 <sup>5</sup>  | fx/2 <sup>5</sup>  | (156 kHz)                            | fx/2 <sup>6</sup>  | (78.1 kHz) | 6  |  |  |
| 1     | 0      | 1     | 1     | fxx/2 <sup>6</sup>  | fx/2 <sup>6</sup>  | (78.1 kHz)                           | fx/2 <sup>7</sup>  | (39.1 kHz) | 7  |  |  |
| 1     | 1      | 0     | 0     | fxx/2 <sup>7</sup>  | fx/2 <sup>7</sup>  | (39.1 kHz)                           | fx/2 <sup>8</sup>  | (19.5 kHz) | 8  |  |  |
| 1     | 1      | 0     | 1     | fxx/2 <sup>8</sup>  | fx/2 <sup>8</sup>  | (19.5 kHz)                           | fx/2 <sup>9</sup>  | (9.8 kHz)  | 9  |  |  |
| 1     | 1      | 1     | 0     | fxx/2 <sup>9</sup>  | fx/2 <sup>9</sup>  | (9.8 kHz)                            | fx/2 <sup>10</sup> | (4.9 kHz)  | 10 |  |  |
| Other | than a | bove  |       | Setting proh        | ibited             |                                      |                    |            |    |  |  |

Caution When a write is performed to BRGC during a communication operation, baud rate generator output is disrupted and communication cannot be performed normally. Therefore, BRGC must not be written to during a communication operation.

#### **Remarks 1.** fx : Main system clock oscillation frequency

2. fxx : Main system clock frequency (fx or fx/2)

- 3. MCS : Oscillation mode selection register (OSMS) bit 0
- **4.** n : Value set in TPS0 to TPS3 ( $1 \le n \le 11$ )
- **5.** Values in parentheses when operated at fx = 5.0 MHz.

The baud rate transmit/receive clock generated is either a signal scaled from the main system clock, or a signal scaled from the clock input from the ASCK pin.

#### (i) Generation of baud rate transmit/receive clock by means of main system clock

The transmit/receive clock is generated by scaling the main system clock. The baud rate generated from the main system clock is obtained with the following expression.

$$[Baud rate] = \frac{f_{XX}}{2^n \times (k+16)} [Hz]$$

fx

where,

: Main system clock oscillation frequency

- fxx : Main system clock frequency (fx or fx/2)
- n : Value set in TPS0 to TPS3 ( $1 \le n \le 11$ )
- k : Value set in MDL0 to MDL3 ( $0 \le k \le 14$ )

| Baud  |                | fx=5.0    | MHz            |           |                | fx=4.1    | 9 MHz          |           |
|-------|----------------|-----------|----------------|-----------|----------------|-----------|----------------|-----------|
| Rate  | MCS=1          |           | MCS=0          | )         | MCS=1          |           | MCS=0          |           |
| (bps) | BRGC Set Value | Error (%) |
| 75    | _              |           | 00H            | 1.73      | 0BH            | 1.14      | EBH            | 1.14      |
| 110   | 06H            | 0.88      | E6H            | 0.88      | 03H            | -2.01     | E3H            | -2.01     |
| 150   | 00H            | 1.73      | E0H            | 1.73      | EBH            | 1.14      | DBH            | 1.14      |
| 300   | E0H            | 1.73      | D0H            | 1.73      | DBH            | 1.14      | СВН            | 1.14      |
| 600   | D0H            | 1.73      | C0H            | 1.73      | СВН            | 1.14      | BBH            | 1.14      |
| 1200  | СОН            | 1.73      | B0H            | 1.73      | BBH            | 1.14      | ABH            | 1.14      |
| 2400  | B0H            | 1.73      | A0H            | 1.73      | ABH            | 1.14      | 9BH            | 1.14      |
| 4800  | A0H            | 1.73      | 90H            | 1.73      | 9BH            | 1.14      | 8BH            | 1.14      |
| 9600  | 90H            | 1.73      | 80H            | 1.73      | 8BH            | 1.14      | 7BH            | 1.14      |
| 19200 | 80H            | 1.73      | 70H            | 1.73      | 7BH            | 1.14      | 6BH            | 1.14      |
| 31250 | 74H            | 0         | 64H            | 0         | 71H            | -1.31     | 61H            | -1.31     |
| 38400 | 70H            | 1.73      | 60H            | 1.73      | 6BH            | 1.14      | 5BH            | 1.14      |
| 76800 | 60H            | 1.73      | 50H            | 1.73      | 5BH            | 1.14      | _              | _         |

#### Table 11-5. Relation between Main System Clock and Baud Rate

★

Remark MCS: Oscillation mode selection register (OSMS) bit 0

(ii) Generation of baud rate transmit/receive clock by means of external clock from ASCK pin The transmit/receive clock is generated by scaling the clock input from the ASCK pin. The baud rate generated from the clock input from the ASCK pin is obtained with the following expression.

[Baud rate] = 
$$\frac{f_{ASCK}}{2 \times (k+16)}$$
 [Hz]

where, fASCK : Frequency of clock input to ASCK pin

k : Value set in MDL0 to MDL3 (0  $\leq$  k  $\leq$  14)

#### Table 11-6. Relation between ASCK Pin Input Frequency and Baud Rate (When BRGC is set to 00H)

| Baud Rate (bps) | ASCK Pin Input Frequency |
|-----------------|--------------------------|
| 75              | 2.4 kHz                  |
| 110             | 3.52 kHz                 |
| 150             | 4.8 kHz                  |
| 300             | 9.6 kHz                  |
| 600             | 19.2 kHz                 |
| 1200            | 38.4 kHz                 |
| 2400            | 76.8 kHz                 |
| 4800            | 153.6 kHz                |
| 9600            | 307.2 kHz                |
| 19200           | 614.4 kHz                |
| 31250           | 1000.0 kHz               |
| 38400           | 1228.8 kHz               |

#### (2) Communication operation

#### (a) Data format

The transmit/receive data format is as shown in Figure 11-7.

#### Figure 11-7. Asynchronous Serial Interface Transmit/Receive Data Format



1 Data frame is configured from the following bits.

- Start bits ..... 1 bit
- Character bits ...... 7 bits/8 bits
- Parity bits ..... Even parity/odd parity/0 parity/no parity
- Stop bit(s) ..... 1 bit/2 bits

The specification of character bit length, parity selection, and specification of stop bit length for each data frame is carried out with asynchronous serial interface mode register (ASIM).

When 7 bits are selected as the number of character bits, only the lower 7 bits (bits 0 to 6) are valid; in transmission the most significant bit (bit 7) is ignored, and in reception the most significant bit (bit 7) is always "0".

The serial transfer rate is selected by means of the ASIM and the baud rate generator control register (BRGC).

If a serial data receive error is generated, the receive error contents can be determined by reading the status of the asynchronous serial interface status register (ASIS).

# (b) Parity types and operation

The parity bit is used to detect a bit error in the communication data. Normally, the same kind of parity bit is used on the transmitting side and the receiving side. With even parity and odd parity, a one-bit (odd number) error can be detected. With 0 parity and no parity, an error cannot be detected.

#### (i) Even parity

#### • Transmission

The number of bits with a value of "1", including the parity bit, in the transmit data is controlled to be even.

The value of the parity bit is as follows:

Number of bits with a value of "1" in transmit data is odd: 1 Number of bits with a value of "1" in transmit data is even: 0

#### • Reception

The number of bits with a value of "1", including the parity bit, in the receive data is counted. If it is odd, a parity error occurs.

#### (ii) Odd parity

### • Transmission

Conversely to the situation with even parity, the number of bits with a value of "1", including the parity bit, in the transmit data is controlled to be odd. The value of the parity bit is as follows:

Number of bits with a value of "1" in transmit data is odd: 0 Number of bits with a value of "1" in transmit data is even: 1

#### • Reception

The number of bits with a value of "1", including the parity bit, in the receive data is counted. If it is even, a parity error occurs.

# (iii) 0 Parity

When transmitting, the parity bit is set to "0" irrespective of the transmit data. At reception, a parity bit check is not performed. Therefore, a parity error is not generated, irrespective of whether the parity bit is set to "0" or "1".

#### (iv) No parity

A parity bit is not added to the transmit data. At reception, data is received assuming that there is no parity bit. Since there is no parity bit, a parity error is not generated.

#### (c) Transmission

A transmit operation is started by writing transmit data to the transmit shift register (TXS). The start bit, parity bit and stop bit(s) are added automatically.

When the transmit operation starts, the data in the transmit shift register (TXS) is shifted out, and when the transmit shift register (TXS) is empty, a transmission completion interrupt request (INTST) is generated.







(b) Stop bit length: 2



Caution Rewriting of the asynchronous serial interface mode register (ASIM) should not be performed during a transmit operation. If rewriting of the ASIM register is performed during transmission, subsequent transmit operations may not be possible (the normal state is restored by RESET input).

It is possible to determine whether transmission is in progress by software by using a transmission completion interrupt request (INTST) or the interrupt request flag (STIF) set by the INTST.

### (d) Reception

When the RXE bit of the asynchronous serial interface mode register (ASIM) is set (1), a receive operation is enabled and sampling of the RxD pin input is performed.

RxD pin input sampling is performed using the serial clock specified by ASIM.

When the RxD pin input becomes low, the 5-bit counter of the baud rate generator (see Figure 11-2) starts counting, and at the time when the half time determined by specified baud rate has passed, the data sampling start timing signal is output. If the RxD pin input sampled again as a result of this start timing signal is low, it is identified as a start bit, the 5-bit counter is initialized and starts counting, and data sampling is performed. When character data, a parity bit and one stop bit are detected after the start bit, reception of one frame of data ends.

When one frame of data has been received, the receive data in the shift register is transferred to the receive buffer register (RXB), and a reception completion interrupt request (INTSR) is generated.

If an error is generated, the receive data in which the error was generated is still transferred to RXB, and INTSR is generated.

If the RXE bit is reset (0) during the receive operation, the receive operation is stopped immediately. In this case, the contents of RXB and ASIS are not changed, and INTSR and INTSER are not generated.

## Figure 11-9. Asynchronous Serial Interface Reception Completion Interrupt Request Timing



Caution The receive buffer register (RXB) must be read even if a receive error is generated. If RXB is not read, an overrun error will be generated when the next data is received, and the receive error state will continue indefinitely.

#### (e) Receive errors

Three kinds of errors can occur during a receive operation: a parity error, framing error, or overrun error. When a data reception results error flag is set in the asynchronous serial interface register (ASIS), a reception error interrupt request (INTSER) is generated.

The reception error interrupt request is generated first before the reception completed interrupt request (INTSR). Receive error causes are shown in Table 11-7.

It is possible to determine what kind of error was generated during reception by reading the contents of the asynchronous serial interface status register (ASIS) in the reception error interrupt servicing (INTSER) (see **Figures 11-9** and **11-10**).

The contents of ASIS are reset (0) by reading the receive buffer register (RXB) or receiving the next data (if there is an error in the next data, the corresponding error flag is set).

| Receive Errors | Cause                                                                                |
|----------------|--------------------------------------------------------------------------------------|
| Parity error   | Transmission-time parity specification and reception data parity do not match        |
| Framing error  | Stop bit not detected                                                                |
| Overrun error  | Reception of next data is completed before data is read from receive register buffer |

# Table 11-7. Receive Error Causes

Figure 11-10. Receive Error Timing



- Cautions 1. The contents of the asynchronous serial interface status register (ASIS) are reset (0) by reading the receive buffer register (RXB) or receiving the next data. To ascertain the error contents, ASIS must be read before reading RXB.
  - 2. The receive buffer register (RXB) must be read even if a receive error is generated. If RXB is not read, an overrun error will be generated when the next data is received, and the receive error state will continue indefinitely.

## (3) UART mode cautions

- (a) In cases where bit 7 (TXE) of the asynchronous serial interface mode register (ASIM) has been cleared and a transmit operation has been terminated during transmission, be sure to set 1 in TXE after setting FFH in the transmit shift register (TXS) before executing the next transmission.
- (b) In cases where bit 6 (RXE) of the asynchronous serial interface mode register (ASIM) has been cleared (0) and a receive operation terminated during reception, enable/disable will differ depending on the timing, the condition of the receive buffer register (RXB), and generation of the reception completed interrupt request (INTSR). The timing is displayed in Figure 11-11.

# Figure 11-11 State of the Receive Buffer Register (RXB) when Reception is Interrupted, and Generation/ Non Generation of an Interrupt Request (INTSR)



When RXE is set to 0 at a time indicated by <1>, RXB holds the previous data and does not generate INTSR. When RXE is set to 0 at a time indicated by <2>, RXB renews the data and does not generate INTSR. When RXE is set to 0 at a time indicated by <3>, RXB renews the data and generates INTSR.

## 11.4.3 3-wire serial I/O mode

The 3-wire serial I/O mode is useful for connection of peripheral I/Os and display controllers, etc., which incorporate a conventional synchronous clocked serial interface, such as the 75X/XL series, 78K series, 17K series, etc. Communication is performed using three lines: the serial clock (SCK2), serial output (SO2), and serial input (SI2).

### (1) Register setting

3-wire serial I/O mode settings are performed using serial operating mode register 2 (CSIM2), the asynchronous serial interface mode register (ASIM), and the baud rate generator control register (BRGC).

## (a) Serial operating mode register 2 (CSIM2)

 $\frac{\text{CSIM2}}{\text{RESET}} \text{ is set with a 1-bit or 8-bit memory manipulation instruction.} \\ \frac{\text{RESET}}{\text{RESET}} \text{ input sets CSIM2 to 00H.} \\ \end{array}$ 



Caution Set 0 to the bits 0 and 3 to 6.

# (b) Asynchronous serial interface mode register (ASIM)

ASIM is set with a 1-bit or 8-bit memory manipulation instruction.  $\overrightarrow{\mathsf{RESET}}$  input sets ASIM to 00H. When the 3-wire serial I/O mode is selected, 00H should be set in ASIM.

Symbol  $\overline{7}$ 6 5 4 3 2 1 0 Address After Reset R/W ASIM TXE RXE PS1 PS0 CL SL ISRM SCK FF70H 00H R/W SCK Clock Selection in Asynchronous Serial Interface Mode 0 Input clock from off-chip to ASCK pin 1 Dedicated baud rate generator output ISRM Control of Reception Completion Interrupt in Case of Error Generation Reception completion interrupt request generated 0 in case of error generation Reception completion interrupt request not 1 generated in case of error generation SL Transmit Data Stop Bit Length Specification 0 1 bit 1 2 bits CL **Character Length Specification** 0 7 bits 1 8 bits PS1 PS0 Parity Bit Specification 0 0 No Parity 0 parity always added in transmission 0 1 No parity test in reception (parity error not generated) 1 0 Odd parity 1 1 Even parity RXE **Receive Operation Control** 0 Receive operation stopped 1 Receive operation enabled TXE **Transmit Operation Control** 0 Transmit operation stopped 1 Transmit operation enabled

# (c) Baud rate generator control register (BRGC)

 $\star$ 

 $\frac{\mathsf{BRGC} \text{ is set with an 8-bit memory manipulation instruction.}}{\mathsf{RESET}}$  input sets BRGC to 00H.

| Symbol | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | Address | After Reset | R/W |
|--------|------|------|------|------|------|------|------|------|---------|-------------|-----|
| BRGC   | TPS3 | TPS2 | TPS1 | TPS0 | MDL3 | MDL2 | MDL1 | MDL0 | FF73H   | 00H         | R/W |

| MDL3 | MDL2 | MDL1 | MDL0 | Baud Rate Generator Input Clock Selection | k  |
|------|------|------|------|-------------------------------------------|----|
| 0    | 0    | 0    | 0    | fscк/16                                   | 0  |
| 0    | 0    | 0    | 1    | fscк/17                                   | 1  |
| 0    | 0    | 1    | 0    | fscк/18                                   | 2  |
| 0    | 0    | 1    | 1    | fscк/19                                   | 3  |
| 0    | 1    | 0    | 0    | fsck/20                                   | 4  |
| 0    | 1    | 0    | 1    | fsck/21                                   | 5  |
| 0    | 1    | 1    | 0    | fsck/22                                   | 6  |
| 0    | 1    | 1    | 1    | fsck/23                                   | 7  |
| 1    | 0    | 0    | 0    | fsck/24                                   | 8  |
| 1    | 0    | 0    | 1    | fsck/25                                   | 9  |
| 1    | 0    | 1    | 0    | fsck/26                                   | 10 |
| 1    | 0    | 1    | 1    | fsck/27                                   | 11 |
| 1    | 1    | 0    | 0    | fsck/28                                   | 12 |
| 1    | 1    | 0    | 1    | fscк/29                                   | 13 |
| 1    | 1    | 1    | 0    | fscк/30                                   | 14 |
| 1    | 1    | 1    | 1    | fscк                                      |    |

(continued)

Remark

- fsck : 5-bit counter source clock
- k : Value set in MDL0 to MDL3 ( $0 \le k \le 14$ )

| TPS3             | TPS2  | TPS1  | TPS0  |                     | 5-Bit Cou          | nter Source C | lock Selecti       | on         | n  |
|------------------|-------|-------|-------|---------------------|--------------------|---------------|--------------------|------------|----|
|                  | 11 02 | 11.01 | 11 00 |                     | MCS=1              |               | MCS=0              |            |    |
| 0                | 0     | 0     | 0     | fxx/2 <sup>10</sup> | fx/2 <sup>10</sup> | (4.9 kHz)     | fx/2 <sup>11</sup> | (2.4 kHz)  | 11 |
| 0                | 1     | 0     | 1     | fxx                 | fx                 | (5.0 MHz)     | fx/2               | (2.5 MHz)  | 1  |
| 0                | 1     | 1     | 0     | fxx/2               | fx/2               | (2.5 MHz)     | fx/2 <sup>2</sup>  | (1.25 MHz) | 2  |
| 0                | 1     | 1     | 1     | fxx/2 <sup>2</sup>  | fx/2 <sup>2</sup>  | (1.25 MHz)    | fx/2 <sup>3</sup>  | (625 kHz)  | 3  |
| 1                | 0     | 0     | 0     | fxx/2 <sup>3</sup>  | fx/2 <sup>3</sup>  | (625 kHz)     | fx/2 <sup>4</sup>  | (313 kHz)  | 4  |
| 1                | 0     | 0     | 1     | fxx/2 <sup>4</sup>  | fx/2 <sup>4</sup>  | (313 kHz)     | fx/2 <sup>5</sup>  | (156 kHz)  | 5  |
| 1                | 0     | 1     | 0     | fxx/2 <sup>5</sup>  | fx/2 <sup>5</sup>  | (156 kHz)     | fx/2 <sup>6</sup>  | (78.1 kHz) | 6  |
| 1                | 0     | 1     | 1     | fxx/2 <sup>6</sup>  | fx/2 <sup>6</sup>  | (78.1 kHz)    | fx/2 <sup>7</sup>  | (39.1 kHz) | 7  |
| 1                | 1     | 0     | 0     | fxx/2 <sup>7</sup>  | fx/2 <sup>7</sup>  | (39.1 kHz)    | fx/2 <sup>8</sup>  | (19.5 kHz) | 8  |
| 1                | 1     | 0     | 1     | fxx/2 <sup>8</sup>  | fx/2 <sup>8</sup>  | (19.5 kHz)    | fx/2 <sup>9</sup>  | (9.8 kHz)  | 9  |
| 1                | 1     | 1     | 0     | fxx/2 <sup>9</sup>  | fx/2 <sup>9</sup>  | (9.8 kHz)     | fx/2 <sup>10</sup> | (4.9 kHz)  | 10 |
| Other than above |       |       |       | Setting proh        | prohibited         |               |                    |            |    |

- Caution When a write is performed to BRGC during a communication operation, baud rate generator output is disrupted and communication cannot be performed normally. Therefore, BRGC must not be written to during a communication operation.
- Remarks 1. fx : Main system clock oscillation frequency
  - 2. fxx : Main system clock frequency (fx or fx/2)
  - 3. MCS : Oscillation mode selection register (OSMS) bit 0
  - **4.** n : Value set in TPS0 to TPS3 ( $1 \le n \le 11$ )
  - **5.** Values in parentheses when operated at fx = 5.0 MHz.

When the internal clock is used as the serial clock in the 3-wire serial I/O mode, set BRGC as described below. BRGC Setting is not required if an external serial clock is used.

#### (i) When the baud rate generator is not used:

Select a serial clock frequency with TPS0-TPS3. Be sure then to set MDL0 to MDL3 to 1,1,1,1. The serial clock frequency becomes the same as the source clock frequency for the 5-bit counter.

#### (ii) When the baud rate generator is used:

Select a serial clock frequency with TPS0-TPS3. Be sure then to set MDL0 to MDL3 to 1,1,1,1.

The serial clock frequency is calculated by the following formula:

Serial clock frequency=  $\frac{f_{XX}}{2^n x (k + 16)}$  [Hz]

**Remarks 1.** fx : Main system clock oscillation frequency

- 2. fxx : Main system clock frequency (fx or fx/2)
- **3.** n : Value set in TPS0 to TPS3 ( $1 \le n \le 11$ )
- 4. k : Value set in MDL0 to MDL3 ( $0 \le k \le 14$ )

## (2) Communication operation

In the 3-wire serial I/O mode, data transmission/reception is performed in 8-bit units. Data is transmitted/ received bit by bit in synchronization with the serial clock.

Transmit shift register (TXS/SIO2) and receive shift register (RXS) shift operations are performed in synchronization with the fall of the serial clock  $\overline{SCK2}$ . Then transmit data is held in the SO2 latch and output from the SO2 pin. Also, receive data input to the SI2 pin is latched in the receive buffer register (RXB/SIO2) on the rise of  $\overline{SCK2}$ .

At the end of an 8-bit transfer, the operation of the TXS/SIO2 or RXS stops automatically, and the interrupt request flag (SRIF) is set.



Figure 11-12. 3-Wire Serial I/O Mode Timing

#### (3) MSB/LSB switching as the start bit

The 3-wire serial I/O mode enables to select transfer to start from MSB or LSB.

Figure 11-13 shows the configuration of the transmission shift register (TXS/SIO2) and internal bus. As shown in the figure, MSB/LSB can be read/written in reverse form.

MSB/LSB switching as the start bit can be specified with bit 2 (CSIM22) of the serial operating mode register 2 (CSIM2).



Figure 11-13. Circuit of Switching in Transfer Bit Order

Start bit switching is realized by switching the bit order for data write to SIO2. The SIO2 shift order remains unchanged.

Thus, switching between MSB-first and LSB-first must be performed before writing data to the shift register.

# (4) Transfer start

\*

Serial transfer is started by setting transfer data to the transmission shift register (TXS/SIO2) when the following two conditions are satisfied.

- Serial interface channel 2 operation control bit (CSIE2) =1
- Internal serial clock is stopped or SCK2 is a high level after 8-bit serial transfer.

# Caution If CSIE2 is set to "1" after data write to TXS/SIO2, transfer does not start.

Upon termination of 8-bit transfer, serial transfer automatically stops and the interrupt request flag (SRIF) is set.

# [MEMO]

# **CHAPTER 12 INTERRUPT FUNCTION**

# 12.1 Interrupt Function Types

The following three types of interrupt functions are used.

# (1) Non-maskable interrupt

This interrupt is acknowledged unconditionally even in the interrupt disabled status. It does not undergo interrupt priority control and is given top priority over all other interrupt requests. It generates a standby release signal.

One of the non-maskable interrupts is the interrupt request from the Watchdog Timer.

#### (2) Maskable interrupts

These interrupts undergo mask control. Maskable interrupts can be divided into a high interrupt priority group and a low interrupt priority group by setting the priority specify flag register (PR0L, PR0H, PR1L). Multiple high priority interrupts can be applied to low priority interrupts. If two or more interrupts with the same priority are simultaneously generated, each interrupts has a predetermined priority (see **Table 12-1**). A standby release signal is generated.

Maskable interrupts include three external interrupt requests and eight internal interrupt requests.

# (3) Software interrupt

This is a vectored interrupt that occurs when the BRK instruction is executed. It is acknowledged even in a disabled state. The software interrupt does not undergo interrupt priority control.

# 12.2 Interrupt Sources and Configuration

There are a total of 13 interrupts, combining non-maskable interrupts, maskable interrupts and software interrupts (see **Table 12-1**).

| Interrupt        | Note 1<br>Default |         | Interrupt Source                                                    | Internal/ | Vector           | Note 2<br>Basic       |
|------------------|-------------------|---------|---------------------------------------------------------------------|-----------|------------------|-----------------------|
| Туре             | Priority          | Name    | Trigger                                                             | External  | Table<br>Address | Configuration<br>Type |
| Non-<br>maskable | _                 | INTWDT  | NTWDT Watchdog timer overflow (with watchdog timer mode 1 selected) |           | 0004H            | (A)                   |
| Maskable         | skable 0 INTWDT   |         | Watchdog timer overflow (with interval timer mode selected)         |           |                  | (B)                   |
|                  | 1                 | INTP1   | Pin input edge detection                                            | External  | 0008H            | (C)                   |
|                  | 2                 | INTP2   |                                                                     |           | 000AH            |                       |
|                  | 3                 | INTP3   |                                                                     |           | 000CH            |                       |
|                  | 4                 | INTSER  | Serial interface channel 2 UART reception error generation          | Internal  | 0018H            | (B)                   |
|                  | 5                 | INTSR   | End of serial interface channel 2<br>UART reception                 |           | 001AH            |                       |
|                  |                   | INTCSI2 | End of serial interface channel 2<br>3-wire transfer                |           |                  |                       |
|                  | 6                 | INTST   | End of serial interface channel 2<br>UART transfer                  |           | 001CH            |                       |
|                  | 7                 | INTAD   | End of A/D converter conversion                                     |           | 0028H            |                       |
|                  | 8                 | INTTM5  | Generation of 8-bit timer/event counter 5 match signal              |           | 002AH            |                       |
|                  | 9                 | INTTM6  | Generation of 8 bit timer/event counter 6 match signal              |           | 002CH            |                       |
| Software         | _                 | BRK     | BRK instruction execution                                           |           | 003EH            | (D)                   |

### Table 12-1. Interrupt Source List

**Notes 1.** Default priorities are intended for two or more simultaneously generated maskable interrupts. 0 is the highest priority and 9 is the lowest priority.

2. Basic configuration types (A) to (D) correspond to (A) to (D) of Figure 12-1.

Figure 12-1. Basic Configuration of Interrupt Function (1/2)

# (A) Internal non-maskable interrupt



### (B) Internal maskable interrupt



# Figure 12-1. Basic Configuration of Interrupt Function (2/2)

# (C) External maskable interrupt



(D) Software interrupt



IE Interrupt enable flag :

- ISP : Inservice priority flag
- MK :
- Interrupt mask flag
- PR : Priority specify flag

# **12.3 Interrupt Function Control Registers**

The following five types of registers are used to control the interrupt functions.

- Interrupt request flag register (IF0L, IF0H, IF1L)
- Interrupt mask flag register (MK0L, MK0H, MK1L)
- Priority specify flag register (PR0L, PR0H, PR1L)
- External interrupt mode register (INTM0, INTM1)
- Program status word (PSW)

Table 12-2 gives a listing of interrupt request flags, interrupt mask flags, and priority specify flags corresponding to interrupt request sources.

| Interrupt Source Interrupt F |       | equest Flag | Interrupt Mask Flag |          | Priority Specify Flag |          |
|------------------------------|-------|-------------|---------------------|----------|-----------------------|----------|
|                              |       | Register    |                     | Register |                       | Register |
| INTWDT                       | TMIF4 | IFOL        | ТММК4               | MKOL     | TMPR4                 | PROL     |
| INTP1                        | PIF1  |             | PMK1                |          | PPR1                  |          |
| INTP2                        | PIF2  |             | PMK2                |          | PPR2                  |          |
| INTP3                        | PIF3  |             | PMK3                |          | PPR3                  |          |
| INTSER                       | SERIF | IF0H        | SERMK               | мкон     | SERPR                 | PR0H     |
| INTSR/INTCSI2                | SRIF  |             | SRMK                |          | SRPR                  |          |
| INTST                        | STIF  |             | STMK                |          | STPR                  |          |
| INTAD                        | ADIF  | IF1L        | ADMK                | MK1L     | ADPR                  | PR1L     |
| INTTM5                       | TMIF5 |             | ТММК5               |          | TMPR5                 |          |
| INTTM6                       | TMIF6 |             | ТММК6               |          | TMPR6                 |          |

Table 12-2. Various Flags Corresponding to Interrupt Request Sources

# (1) Interrupt request flag registers (IF0L, IF0H, IF1L)

The interrupt request flag is set to 1 when the corresponding interrupt request is generated or an instruction is executed. It is cleared to 0 when an instruction is executed upon acknowledgment of an interrupt request or upon application of RESET input.

IF0L, IF0H, and IF1L are set with a 1-bit or 8-bit memory manipulation instruction. If IF0L and IF0H are used as a 16-bit register IF0 use a 16-bit memory manipulation instruction for the setting.

RESET input sets these registers to 00H.



#### Figure 12-2. Interrupt Request Flag Register Format

- Cautions 1. TMIF4 flag is R/W enabled only when a watchdog timer is used as an interval timer. If a watchdog timer is used in watchdog timer mode 1, set TMIF4 flag to 0.
  - 2. Set 0 to the bits 1, 5 to 7 of IF0L and bits 0, 1, 5 to 7 of IF0H and IF1L.

## (2) Interrupt mask flag registers (MK0L, MK0H, MK1L)

The interrupt mask flag is used to enable/disable the corresponding maskable interrupt service and to set standby clear enable/disable.

MK0L, MK0H, and MK1L are set with a 1-bit or 8-bit memory manipulation instruction. If MK0L and MK0H are used as a 16-bit register MK0, use a 16-bit memory manipulation instruction for the setting. RESET input sets these registers to FFH.



### Figure 12-3. Interrupt Mask Flag Register Format

- Cautions 1. If TMMK4 flag is read when a watchdog timer is used in watchdog timer mode 1, MK0 value becomes undefined.
  - 2. Because port 0 has a dual function as the external interrupt request input, when the output level is changed by specifying the output mode of the port function, an interrupt request flag is set. Therefore, 1 should be set in the interrupt mask flag before using the output mode.
  - 3. Set 1 to the bits 1, 5 to 7 of MK0L and bits 0, 1, 5 to 7 of MK0H and MK1L.

# (3) Priority specify flag registers (PR0L, PR0H, and PR1L)

The priority specify flag is used to set the corresponding maskable interrupt priority orders. PR0L, PR0H, and PR1L are set with a 1-bit or 8-bit memory manipulation instruction. If PR0L and PR0H are used as a 16-bit register PR0, use a 16-bit memory manipulation instruction for the setting. RESET input sets these registers to FFH.



# Figure 12-4. Priority Specify Flag Register Format

Cautions 1. If a watchdog timer is used in watchdog timer mode 1, set TMPR4 flag to 1. 2. Set 1 to the bits 1, 5 to 7 of PR0L and bits 0, 1, 5 to 7 of PR0H and PR1L.

# (4) External interrupt mode register (INTM0, INTM1)

These registers set the valid edge for INTP1 to INTP3. INTM0 and INTM1 are set by 8-bit memory manipulation instructions. RESET input sets these registers to 00H.



# Figure 12-5. External Interrupt Mode Register 0 Format

Caution Set 0 to the bits 0 to 3.

### Figure 12-6. External Interrupt Mode Register 1 Format



### Caution Set 0 to the bits 2 to 7.

# (5) Program status word (PSW)

The program status word is a register to hold the instruction execution result and the current status for interrupt request. The IE flag to set maskable interrupt enable/disable and the ISP flag to control multiple interrupt processing are mapped.

Besides 8-bit unit read/write, this register can carry out operations with a bit manipulation instruction and dedicated instructions (EI and DI). When a vectored interrupt request is acknowledged or when the BRK instruction is executed, the contents of PSW is automatically saved to the stack and the IE flag is reset to 0. If a maskable interrupt request is acknowledged the contents of the priority specify flag of the acknowledged interrupt are transferred to the ISP flag. The contents of PSW are also saved to the stack by the PUSH PSW instruction. It is reset from the stack with the RETI, RETB, and POP PSW instructions. RESET input sets PSW to 02H.



Figure 12-7. Program Status Word Configuration

### 12.4 Interrupt Servicing Operations

#### 12.4.1 Non-maskable interrupt request acknowledge operation

A non-maskable interrupt request is unconditionally acknowledged even if in an interrupt request acknowledge disable state. It does not undergo interrupt priority control and has highest priority over all other interrupts.

If a non-maskable interrupt request is acknowledged, the contents of program status word (PSW) and program counter (PC), in that order, are saved to the stack, the IE flag and ISP flag are reset (0), and the contents of the vector table are loaded in the PC and branched.

A new non-maskable interrupt request generated during execution of a non-maskable interrupt servicing program is acknowledged after the current execution of the non-maskable interrupt servicing program is terminated (following RETI instruction execution) and one main routine instruction is executed. If a new non-maskable interrupt request is generated twice or more during non-maskable interrupt service program execution, only one non-maskable interrupt request is acknowledged after termination of the non-maskable interrupt service program execution.

The flowchart showing the flow from non-maskable interrupt request generation to acknowledgment is shown in Figure 12-8, the non-maskable interrupt request acknowledge timing is shown in Figure 12-9, and acknowledge operation in the case where multiple non-maskable interrupt requests are generated, is shown in Figure 12-10.





WDTM : Watchdog timer mode register WDT : Watchdog timer



| CPU Instruction | Instruction  | Instruction                                  | PSW and PC Save, Jump to Interrupt Servicing | Interrupt Sevicing<br>Program |
|-----------------|--------------|----------------------------------------------|----------------------------------------------|-------------------------------|
| TMIF4           |              | //////////////////////////////////////       |                                              |                               |
|                 |              |                                              |                                              |                               |
|                 | Interrupt re | equests which generate within this space are | acknowledged with $\uparrow$ tir             | ning.                         |

TMIF4 : Watchdog timer interrupt request flag

- Figure 12-10. Non-Maskable Interrupt Request Acknowledge Operation
  - (a) If a new non-maskable interrupt request is generated during non-maskable interrupt servicing program execution



(b) If two non-maskable interrupt requests are generated during non-maskable interrupt servicing program execution



#### 12.4.2 Maskable interrupt request acknowledge operation

A maskable interrupt request becomes acknowledgeable when an interrupt request flag is set to 1 and the interrupt mask (MK) flag is cleared to 0. A vectored interrupt request is acknowledged in an interrupt enable state (with IE flag set to 1). However, a low-priority interrupt request is not acknowledged during high-priority interrupt service (with ISP flag reset to 0).

The waiting time from the point when a maskable interrupt request is generated until interrupt processing is executed is as shown in Table 12-3.

Please refer to Figures 12-12 and 12-13 concerning interrupt request acknowledgement timing.

Table 12-3. Times from Maskable Interrupt Request Generation to Interrupt Service

|             | Minimum Time | Maximum Time <sup>Note</sup> |
|-------------|--------------|------------------------------|
| When ××PR=0 | 7 clocks     | 32 clocks                    |
| When ××PR=1 | 8 clocks     | 33 clocks                    |

Note If an interrupt request is generated just before a divide instruction, the wait time is maximized.

If two or more maskable interrupt requests are generated simultaneously, the request specified for higher priority with the priority specify flag is acknowledged first. Also, when the same priority is specified with the priority specify flag, the interrupt request with the higher default priority is acknowledged first.

Any reserved interrupt requests are acknowledged when they become acknowledgeable.

Figure 12-11 shows interrupt request acknowledge algorithms.

If a maskable interrupt request is acknowledged, the contents are saved to the stack in the order of first, program status word (PSW), then, program counter (PC), then the IE flag is reset (0) and the contents of the acknowledged interrupt request priority specification flag are transferred to the ISP flag.

Further, the data in the vector table which has been determined with each interrupt request, are loaded into the PC and branched.

Return from the interrupt is possible with the RETI instruction.



Figure 12-11. Interrupt Request Acknowledge Processing Algorithm

- ××IF : Interrupt request flag
- ××MK : Interrupt mask flag
- ××PR : Priority specify flag
- IE : Flag which controls maskable interrupt request acknowledgment (1 = enable, 0 = disable)
- ISP : Flag which indicates the priority of the interrupt currently being processed. (0 = high priority interrupt being processed, 1= interrupt request not acknowledged, or low priority interrupt being processed.)



#### Figure 12-12. Interrupt Request Acknowledge Timing (Minimum Time)

#### 12.4.3 Software interrupt request acknowledge operation

A software interrupt request is acknowledged by BRK instruction execution. Software interrupt cannot be disabled. If a software interrupt request is acknowledged, the contents are saved to the stack in the order of first, program status word (PSW), then the program counter (PC), then the IE flag is reset (0) and the contents of the vector tables (003EH, 003FH) are loaded into the PC and branched.

Return from the software interrupt is possible with the RETB instruction.

#### Caution Do not use the RETI instruction for returning from the software interrupt.

#### 12.4.4 Multiple interrupt servicing

When another interrupt is acknowledged while an interrupt is being processed, this is called multiple interrupt. Multiple interrupts are not generated unless interrupt request acknowledge is enabled (IE = 1) (non-maskable interrupts excepted). Also, at the point when an interrupt request is acknowledged, acknowledgment of other interrupt requests is disabled (IE = 0). Therefore, in order to enable multiple interrupts, it is necessary during interrupt processing to set the IE flag (1) using the IE instruction, and enable interrupts.

There are cases where multiple requests are not enabled even though interrupts are enabled. However, this is controlled by the priority of the interrupt. There are two interrupt priorities, the default priority and the programmable priority. Multiple interrupt control is handled by programmable priority control.

In interrupt enabled condition, when an interrupt request is generated which is the same level, or which has a higher priority than the interrupt currently being processed, it is acknowledged as a multiple interrupt. When an interrupt request is generated which has a lower priority than the interrupt currently being processed, it is not acknowledged as a multiple interrupt.

Interrupt requests which have not been permitted as multiple interrupts because of low priority or because of the interrupt being disabled, are reserved, and after the current interrupt processing has been completed, they are acknowledged after executing one of the main processing instructions.

Multiple interrupts are not permitted during non-maskable interrupt processing.

Multiple interrupt enabled interrupt requests are shown in Table 12-4, and an example of multiple interrupts is given in Figure 12-14.

# Table 12-4. Interrupt Request Enabled for Multiple Interrupt during Interrupt Servicing

|                      | Multiple Interrupt<br>Request |           |      | Maskable Interrupt Request |      |      |  |
|----------------------|-------------------------------|-----------|------|----------------------------|------|------|--|
|                      | equesi                        | Interrupt | PR=0 |                            | PR=1 |      |  |
| during processing    |                               | Request   | IE=1 | IE=0                       | IE=1 | IE=0 |  |
| Non-maskable interru | Non-maskable interrupt        |           | D    | D                          | D    | D    |  |
| Maskable interrupt   | ISP=0                         | E         | E    | D                          | D    | D    |  |
|                      | ISP=1                         | E         | E    | D                          | Е    | D    |  |
| Software interrupt   |                               | E         | Е    | D                          | E    | D    |  |

#### **Remarks 1.** E : Multiple interrupt enable

- 2. D : Multiple interrupt disable
- 3. ISP and IE are the flags contained in PSW
  - ISP=0 : An interrupt with higher priority is being serviced
  - ISP=1 : An interrupt request is not accepted or an interrupt with lower priority is being serviced
  - IE=0 : Interrupt request acknowledge is disabled
  - IE=1 : Interrupt request acknowledge is enabled
- 4. PR is a flag contained in PR0L, PR0H, and PR1L
  - PR=0 : Higher priority level
  - PR=1 : Lower priority level

#### Figure 12-14. Multiple Interrupt Example (1/2)



Example 1. Example of when a multiple interrupt is generated twice.

Two interrupt requests, INTyy and INTzz, are acknowledged during processing of interrupt INTxx, and a multiple interrupt is generated. Before each interrupt request is acknowledged, the EI instruction is always executed and interrupt request acknowledgment enabled.

Example 2. Example of when a multiple interrupt is not generated because of priority control.



Interrupt request INTyy, which has been generated during processing of interrupt INTxx, and which has an interrupt priority that is lower than that of INTxx, is not acknowledged, and a multiple interrupt is not generated. Interrupt request INTyy is reserved and is acknowledged after execution of one main processing instructions.

PR = 0 : High priority level

PR = 1 : Low priority level

IE = 0 : Interrupt request acknowledge disabled



### Figure 12-14 Multiple Interrupt Example (2/2)

Example 3. Example of when a multiple interrupt is not generated because interrupts are not enabled.

Because interrupts are not enabled (the EI instruction is not executed) during processing of interrupt INTxx, interrupt request INTyy is not acknowledged and a multiple interrupt is not generated. Interrupt request INTyy is reserved and acknowledged after one main processing instruction is implemented.

PR = 0 : High priority level

IE = 0 : Interrupt request acknowledge disabled.

### 12.4.5 Interrupt request reserve

There are some instructions which, though an interrupt request may be generated while they are being executed, will reserve the acknowledgment of the request until after execution of the next instruction. These instructions (interrupt request reserve instructions) are shown below.

- MOV PSW, #byte
- MOV A, PSW
- MOV PSW, A
- MOV1 PSW.bit, CY
- MOV1 CY, PSW.bit
- AND1 CY, PSW.bit
- OR1 CY, PSW.bit
- XOR1 CY, PSW.bit
- SET1 PSW.bit
- CLR1 PSW.bit
- RETB
- RETI
- PUSH PSW
- POP PSW
- BT PSW.bit, \$addr16
- BF PSW.bit, \$addr16
- BTCLR PSW.bit, \$addr16
- EI
- DI
- Manipulate instructions for IF0L, IF0H, IF1L, MK0L, MK0H, MK1L, PR0L, PR0H, PR1L, INTM0, INTM1 registers
- Caution The BRK instruction is not one of the above interrupt request reserve instructions. However in the case of software interrupts, which are activated by execution of the BRK instruction, the IE flag is cleared to 0. Therefore, even if a maskable interrupt request is generated during BRK instruction execution, the interrupt request will not be acknowledged. However, non-maskable interrupt requests will be acknowledged.

The interrupt request reserve timing is shown in Figure 12-15.

| CPU processing | Instruction N | Instruction M | Save PSW and PC,<br>Jump to interrupt service | Interrupt service program |
|----------------|---------------|---------------|-----------------------------------------------|---------------------------|
| ××IF           |               |               |                                               |                           |

# Figure 12-15. Interrupt Request Hold

Remarks 1. Instruction N: Instruction that holds interrupts requests

2. Instruction M: Instructions other than instruction N

3. The operation of  $\times$ IF (interrupt request) is not affected by  $\times$ PR (priority level) values.

# CHAPTER 13 STANDBY FUNCTION

# **13.1 Standby Function and Configuration**

# 13.1.1 Standby function

The standby function is designed to decrease power consumption of the system. The following two modes are available.

## (1) HALT mode

HALT instruction execution sets the HALT mode. The HALT mode is intended to stop the CPU operation clock. System clock oscillator continues oscillation. In this mode, current consumption cannot be decreased as in the STOP mode. The HALT mode is valid to restart immediately upon interrupt request and to carry out intermittent operations.

## (2) STOP mode

STOP instruction execution sets the STOP mode. In the STOP mode, the main system clock oscillator stops and the whole system stops. CPU current consumption can be considerably decreased.

Data memory low-voltage hold (down to  $V_{DD} = 1.8 \text{ V}$ ) is possible. Thus, the STOP mode is effective to hold data memory contents with ultra-low current consumption. Because this mode can be cleared upon interrupt request, it enables intermittent operations to be carried out.

However, because a wait time is necessary to secure an oscillation stabilization time after the STOP mode is cleared, select the HALT mode if it is necessary to start processing immediately upon interrupt request.

In any mode, all the contents of the register, flag and data memory just before standby mode setting are held. The input/output port output latch and output buffer statuses are also held.

- Cautions 1. When proceeding to the STOP mode, be sure to stop the peripheral hardware operation and execute the STOP instruction.
  - 2. The following sequence is recommended for power consumption reduction of the A/D converter when the standby function is used: first clear bit 7 (CS) of A/D converter mode register (ADM) to 0 to stop the A/D conversion operation, and then execute the HALT or STOP instruction.

#### 13.1.2 Standby function control register

A wait time after the STOP mode is cleared upon interrupt request till the oscillation stabilizes is controlled with the oscillation stabilization time select register (OSTS).

OSTS is set with an 8-bit memory manipulation instruction.

RESET input sets OSTS to 04H. However, it takes 2<sup>17</sup>/fx, not 2<sup>18</sup>/fx, until the STOP mode is cleared by RESET input.

| Figure 13-1. | Oscillation | Stabilization | Time | Select | Register | Format |
|--------------|-------------|---------------|------|--------|----------|--------|
|--------------|-------------|---------------|------|--------|----------|--------|

| Symbol | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     | Address |        | After<br>Reset | R/W                              |                                                  |                                           |
|--------|---|---|---|---|---|-------|-------|-------|---------|--------|----------------|----------------------------------|--------------------------------------------------|-------------------------------------------|
| OSTS   | 0 | 0 | 0 | 0 | 0 | OSTS2 | OSTS1 | OSTS0 | F       | FFAH   |                | 04H                              | R/W                                              |                                           |
| _      |   |   |   |   |   |       |       |       |         |        |                |                                  |                                                  |                                           |
|        |   |   |   |   |   |       |       |       | οετερ   | 00701  | OSTS0          | Tim                              | ction of Oscillation<br>when STOP Mode           |                                           |
|        |   |   |   |   |   |       |       |       | 03132   | 03131  | 03130          |                                  | MCS = 1                                          | MCS = 0                                   |
|        |   |   |   |   |   |       |       |       | 0       | 0      | 0              | 2 <sup>12</sup> /f <sub>xx</sub> | 2 <sup>12</sup> /f <sub>x</sub> (819 <i>m</i> s) | 2 <sup>13</sup> /f <sub>x</sub> (1.64 ms) |
|        |   |   |   |   |   |       |       |       | 0       | 0      | 1              | 2 <sup>14</sup> /f <sub>xx</sub> | 2 <sup>14</sup> /f <sub>x</sub> (3.28 ms)        | 2 <sup>15</sup> /f <sub>x</sub> (6.55 ms) |
|        |   |   |   |   |   |       |       |       | 0       | 1      | 0              | 2 <sup>15</sup> /f <sub>xx</sub> | 2 <sup>15</sup> /f <sub>x</sub> (6.55 ms)        | 2 <sup>16</sup> /f <sub>x</sub> (13.1 ms) |
|        |   |   |   |   |   |       |       |       | 0       | 1      | 1              | 2 <sup>16</sup> /f <sub>xx</sub> | 2 <sup>16</sup> /f <sub>x</sub> (13.1 ms)        | 2 <sup>17</sup> /f <sub>x</sub> (26.2 ms) |
|        |   |   |   |   |   |       |       |       | 1       | 0      | 0              | 2 <sup>17</sup> /f <sub>xx</sub> | 2 <sup>17</sup> /f <sub>x</sub> (26.2 ms)        | 2 <sup>18</sup> /f <sub>x</sub> (52.4 ms) |
|        |   |   |   |   |   |       |       |       | Other   | than a | above          | Setting                          | prohibited                                       |                                           |

Caution The wait time after STOP mode clear does not include the time (see "a" in the illustration below) from STOP mode clear to clock oscillation start, regardless of clearance by **RESET** input or by interrupt generation.



- Remarks 1. fxx : Main system clock frequency (fx or fx/2)
  - 2. fx : Main system clock oscillation frequency
  - 3. MCS : Oscillation mode select register (OSMS) bit 0
  - 4. Values in parentheses when operated at fx = 5.0 MHz

# 13.2 Standby Function Operations

## 13.2.1 HALT mode

## (1) HALT mode set and operating status

The HALT mode is set by executing the HALT instruction. The operating status in the HALT mode is described below.

## Table 13-1. HALT Mode Operating Status

| Item                           | HALT Mode Operating Status                             |
|--------------------------------|--------------------------------------------------------|
| Clock generator                | Can be oscillated. Supply to the CPU clock is stopped. |
| CPU                            | Operation stops.                                       |
| Port                           | Status before HALT mode setting is held.               |
| 8-bit timer/event counter 5, 6 | Operable.                                              |
| Watchdog timer                 |                                                        |
| A/D converter                  |                                                        |
| Serial interface               |                                                        |
| External interrupt request     |                                                        |

#### (2) HALT mode clear

The HALT mode can be cleared with the following three types of sources.

#### (a) Clear upon unmasked interrupt request

An unmasked interrupt request is used to clear the HALT mode. If interrupt acknowledge is enabled, vectored interrupt service is carried out. If disabled, the next address instruction is executed.





- **Remarks 1.** The broken line indicates the case when the interrupt request which has cleared the standby status is acknowledged.
  - 2. Wait time will be as follows:
    - When vectored interrupt service is carried out:
       8 to 9 clocks
    - When vectored interrupt service is not carried out: 2 to 3 clocks

#### (b) Clear upon non-maskable interrupt request

The HALT mode is cleared and vectored interrupt service is carried out whether interrupt acknowledge is enabled or disabled.

## (c) Clear upon RESET input

As is the case with normal reset operation, a program is executed after branch to the reset vector address.

Figure 13-3. HALT Mode Release by RESET Input



Remarks 1. fx: main system clock oscillation frequency

**2.** Values in parentheses when operated at  $f_x = 5.0 \text{ MHz}$ 

| Release Source                 | MK×× | PR×× | IE | ISP | Operation                          |
|--------------------------------|------|------|----|-----|------------------------------------|
| Maskable interrupt             | 0    | 0    | 0  | ×   | Next address instruction execution |
| request                        | 0    | 0    | 1  | ×   | Interrupt service execution        |
|                                | 0    | 1    | 0  | 1   | Next address instruction execution |
|                                | 0    | 1    | ×  | 0   |                                    |
|                                | 0    | 1    | 1  | 1   | Interrupt service execution        |
|                                | 1    | ×    | ×  | ×   | HALT mode hold                     |
| Non-maskable interrupt request | _    | _    | ×  | ×   | Interrupt service execution        |
| RESET input                    | -    | -    | ×  | ×   | Reset processing                   |

Table 13-2. Operation after HALT Mode Release

Remark ×: Don't care

#### 13.2.2 STOP mode

#### (1) STOP mode set and operating status

The STOP mode is set by executing the STOP instruction.

- Cautions 1. When the STOP mode is set, the X2 pin is internally connected to V<sub>DD</sub> via a pull-up resistor to minimize the leakage current at the crystal oscillator. Thus, do not use the STOP mode in a system where an external clock is used for the main system clock.
  - 2. Because the interrupt request signal is used to clear the standby mode, if there is an interrupt source with the interrupt request flag set and the interrupt mask flag reset, the standby mode is immediately cleared if set. Thus, the STOP mode is reset to the HALT mode immediately after execution of the STOP instruction. After the wait set using the oscillation stabilization time select register (OSTS), the operating mode is set.

The operating status in the STOP mode is described below.

| Item                           | STOP Mode Operating Status                                   |
|--------------------------------|--------------------------------------------------------------|
| Clock generator                | Oscillation stops.                                           |
| CPU                            | Operation stops.                                             |
| Port                           | Status before STOP mode setting is held.                     |
| 8-bit timer/event counter 5, 6 | Operable when TI5 and TI6 are selected for the count clock.  |
| Watchdog timer                 | Operation stops.                                             |
| A/D converter                  |                                                              |
| Serial interface               | Three-wire serial I/O is operable when the externally input  |
|                                | clock is selected as the serial clock. UART operation stops. |
| External interrupt request     | Operable.                                                    |

#### Table 13-3. STOP Mode Operating Status

#### (2) STOP mode release

The STOP mode can be cleared with the following two types of sources.

#### (a) Release by unmasked interrupt request

An unmasked interrupt request is used to release the STOP mode. If interrupt acknowledge is enabled after the lapse of oscillation stabilization time, vectored interrupt service is carried out. If interrupt acknowledge is disabled, the next address instruction is executed.





**Remark** The broken line indicates the case when the interrupt request which has cleared the standby status is acknowledged.

## (b) Release by RESET input

The STOP mode is cleared and after the lapse of oscillation stabilization time, reset operation is carried out.





Remarks 1. fx: main system clock oscillation frequency

**2.** Values in parentheses when operated at fx = 5.0 MHz

| Table 13-4. | Operation a | after STOP | Mode | Release |
|-------------|-------------|------------|------|---------|
|-------------|-------------|------------|------|---------|

| Release Source             | MK×× | PR×× | IE | ISP | Operation                          |
|----------------------------|------|------|----|-----|------------------------------------|
| Maskable interrupt request | 0    | 0    | 0  | ×   | Next address instruction execution |
|                            | 0    | 0    | 1  | ×   | Interrupt service execution        |
|                            | 0    | 1    | 0  | 1   | Next address instruction execution |
|                            | 0    | 1    | ×  | 0   |                                    |
|                            | 0    | 1    | 1  | 1   | Interrupt service execution        |
|                            | 1    | ×    | ×  | ×   | STOP mode hold                     |
| RESET input                | _    | _    | ×  | ×   | Reset processing                   |

Remark ×: Don't care

## **CHAPTER 14 RESET FUNCTION**

#### 14.1 Reset Function

The following two operations are available to generate the reset signal.

- (1) External reset input with RESET pin
- (2) Internal reset by watchdog timer overrun time detection

External reset and internal reset have no functional differences. In both cases, program execution starts at the address at 0000H and 0001H by RESET input.

When a low level is input to the RESET pin or the watchdog timer overflows, a reset is applied and each hardware is set to the status as shown in Table 14-1. Each pin has high impedance during reset input or during oscillation stabilization time just after reset clear.

When a high level is input to the  $\overrightarrow{\text{RESET}}$  input, the reset is cleared and program execution starts after the lapse of oscillation stabilization time (2<sup>17</sup>/fx). The reset applied by watchdog timer overflow is automatically cleared after a reset and program execution starts after the lapse of oscillation stabilization time (2<sup>17</sup>/fx) (see **Figure 14-2** to **14-4**).

Cautions 1. For an external reset, input a low level for 10  $\mu$ s or more to the RESET pin.

- 2. Main system clock oscillation stops during reset input.
- 3. When the STOP mode is cleared by reset, the STOP mode contents are held during reset input. However, the port pin becomes high-impedance.



Figure 14-1. Block Diagram of Reset Function



Figure 14-2. Timing of Reset Input by RESET Input

|                                | Hardware                                                                     | Status after Reset |  |  |  |
|--------------------------------|------------------------------------------------------------------------------|--------------------|--|--|--|
| Program counter (PC) Note1     | Program counter (PC) Note1                                                   |                    |  |  |  |
| Stack pointer (SP)             |                                                                              | Undefined          |  |  |  |
| Program status word (PSW)      |                                                                              | 02H                |  |  |  |
| RAM                            | Data memory                                                                  | Undefined Note2    |  |  |  |
|                                | General register                                                             | Undefined Note2    |  |  |  |
| Port (Output latch)            | Port 0, Port 1, Port 3, Port 5, Port 7,<br>Port 10 (P0, P1, P3, P5, P7, P10) | 00H                |  |  |  |
| Port mode register (PM0, PM    | M1, PM3, PM5, PM7, PM10)                                                     | FFH                |  |  |  |
| Pull-up resistor option regist | er (PUOH, PUOL)                                                              | 00H                |  |  |  |
| Processor clock control regis  | 04H                                                                          |                    |  |  |  |
| Oscillation mode selection re  | 00H                                                                          |                    |  |  |  |
| Memory size switching regis    | Note3                                                                        |                    |  |  |  |
| Oscillation stabilization time | 04H                                                                          |                    |  |  |  |
| Timer clock selection registe  | 00H                                                                          |                    |  |  |  |
| 8-bit timer/event counter      | Timer register (TM5, TM6)                                                    | 00H                |  |  |  |
| 5 and 6                        | Compare registers (CR50, CR60)                                               | 00H                |  |  |  |
|                                | Clock select register (TCL5, TCL6)                                           | 00H                |  |  |  |
|                                | Mode control registers (TMC5, TMC6)                                          | 00H                |  |  |  |
| Watchdog timer                 | Clock select register (TCL2)                                                 | 00H                |  |  |  |
|                                | Mode register (WDTM)                                                         | 00H                |  |  |  |
| Serial Interface               | Mode register (CSIM2)                                                        | 00H                |  |  |  |
|                                | Asynchronous serial interface mode register (ASIM)                           | 00H                |  |  |  |
|                                | Asynchronous serial interface status register (ASIS)                         | 00H                |  |  |  |
|                                | Baud rate generator control register (BRGC)                                  | 00H                |  |  |  |
|                                | Transmit shift register (TXS)                                                | FFH                |  |  |  |
|                                | Receive buffer register (RXB)                                                |                    |  |  |  |
| A/D converter                  | Mode register (ADM)                                                          | 01H                |  |  |  |
|                                | Conversion result register (ADCR)                                            | Undefined          |  |  |  |
|                                | Input select register (ADIS)                                                 | 00H                |  |  |  |

## Table 14-1. Hardware Status after Reset (1/2)

## Table 14-1. Hardware Status after Reset (2/2)

|           | Status after Reset                                |     |
|-----------|---------------------------------------------------|-----|
| Interrupt | Request flag register (IF0L, IF0H, IF1L)          | 00H |
|           | Mask flag register (MK0L, MK0H, MK1L)             | FFH |
|           | Priority specify flag register (PR0L, PR0H, PR1L) | FFH |
|           | External interrupt mode register (INTM0, INTM1)   | 00H |

**Notes 1.** During reset input or oscillation stabilization time wait, only the PC contents among the hardware statuses become undefined. All other hardware statuses remains unchanged after reset.

2. The post-reset status is held in the standby mode.

**3.** The values after reset depend on the product. μPD78081 : 82H, μPD78082 : 64H, μPD78P083 : 46H

## **CHAPTER 15** *µ***PD78P083**

The  $\mu$ PD78P083 is a single-chip microcontroller with an on-chip one-time PROM or with an on-chip EPROM which has program write, erasure and rewrite capability.

Differences between the  $\mu$ PD78P083 and mask ROM versions are shown in Table 15-1.

| Parameter                                                       | μPD78P083           | Mask ROM Versions    |  |  |
|-----------------------------------------------------------------|---------------------|----------------------|--|--|
| Internal ROM type                                               | One-time PROM/EPROM | Mask ROM             |  |  |
| Internal ROM capacity                                           | 24 Kbytes           | μPD78081 : 8 Kbytes  |  |  |
|                                                                 |                     | μPD78082 : 16 Kbytes |  |  |
| Internal high-speed RAM capacity                                | 512 bytes           | μPD78081 : 256 bytes |  |  |
|                                                                 |                     | μPD78082 : 384 bytes |  |  |
| Internal ROM and internal high-speed                            | Enable Note         | Disable              |  |  |
| RAM capacity change by internal                                 |                     |                      |  |  |
| memory size switching register (IMS)                            |                     |                      |  |  |
| IC pin                                                          | Not available       | Available            |  |  |
| VPP pin                                                         | Available           | Not available        |  |  |
| Electrical specifications Refer to a data sheet of each product |                     |                      |  |  |

Table 15-1. Differences between the  $\mu$ PD78P083 and Mask ROM Versions

**Note** The internal PROM becomes 24 Kbytes and the internal expansion RAM becomes 512 bytes by the RESET input.

★ Caution Noise resistance and noise radiation differs between PROM versions and Mask ROM versions. If studying the replacement of PROM versions with mask ROM versions in the process of prototype to volume production, do a thorough evaluation with mask ROM versions with CS versions (not ES versions).

#### 15.1 Memory Size Switching Register

It is possible to specify the internal memory of the  $\mu$ PD78P083 by means of the memory size switching register (IMS). By setting the IMS, memory mapping can be made to match the memory mapping of the  $\mu$ PD78081 and 78082, which have different internal memory.

IMS is set with an 8-bit memory manipulation instruction.

RESET input sets IMS to 46H.





#### Caution If using mask ROM versions, do not specify any values in the IMS other than when resetting.

The IMS settings to give the same memory map as mask ROM versions are shown in Table 15-2.

Table 15-2. Examples of Memory Size Switching Register Settings

| Relevant Mask ROM Version | IMS Setting |
|---------------------------|-------------|
| μPD78081                  | 82H         |
| μPD78082                  | 64H         |

#### 15.2 PROM Programming

The  $\mu$ PD78P083 incorporate a 24-Kbyte PROM as program memory, respectively. To write a program into the  $\mu$ PD78P083 PROM, make the device enter the PROM programming mode by setting the levels of the V<sub>PP</sub> and RESET pins as specified. For the connection of unused pins, see paragraph (2) "PROM programming mode" in section 1.5 Pin Configuration (Top View).

# Caution Perform program writing only in the 0000H to 5FFFH address range (specify the last address as 5FFFH.)

The program cannot be correctly written by a PROM programmer which does not have a write address specification function.

#### 15.2.1 Operating modes

When +5 V or +12.5 V is applied to the VPP pin and a low-level signal is applied to the RESET pin, the  $\mu$ PD78P083 are set to the PROM programming mode. This is one of the operating modes shown in Table 15-3 below according to the setting of the  $\overline{CE}$ ,  $\overline{OE}$ , and  $\overline{PGM}$  pins.

The PROM contents can be read by setting the read mode.

|                 | Pin | RESET | Vpp     | Vdd    | CE | ŌE | PGM | D0-D7          |
|-----------------|-----|-------|---------|--------|----|----|-----|----------------|
| Operating mode  |     |       |         |        |    |    |     |                |
| Page data latch |     | L     | +12.5 V | +6.5 V | н  | L  | н   | Data input     |
| Page write      |     |       |         |        | Н  | Н  | L   | High impedance |
| Byte write      |     |       |         |        | L  | Н  | L   | Data input     |
| Program verify  |     |       |         |        | L  | L  | н   | Data output    |
| Program inhibit |     |       |         |        | ×  | Н  | н   | High impedance |
|                 |     |       |         |        | ×  | L  | L   |                |
| Read            |     |       | +5 V    | +5V    | L  | L  | н   | Data output    |
| Output disabled |     |       |         |        | L  | Н  | ×   | High impedance |
| Standby         |     |       |         |        | Н  | ×  | ×   | High impedance |

| Table 15-3. | PROM | Programming | Operating | Modes |
|-------------|------|-------------|-----------|-------|
|-------------|------|-------------|-----------|-------|

Remark ×: L or H

#### (1) Read mode

Read mode is set by setting  $\overline{CE}$  to L and  $\overline{OE}$  to L.

#### (2) Output disable mode

If  $\overline{OE}$  is set to H, data output becomes high impedance and the output disable mode is set. Therefore, if multiple  $\mu$ PD78P083s are connected to the data bus, data can be read from any one device by controlling the  $\overline{OE}$  pin.

#### (3) Standby mode

Setting  $\overline{CE}$  to H sets the standby mode. In this mode, data output becomes high impedance irrespective of the status of  $\overline{OE}$ .

#### (4) Page data latch mode

Setting  $\overline{CE}$  to H,  $\overline{PGM}$  to H, and  $\overline{OE}$  to L at the start of the page write mode sets the page data latch mode. In this mode, 1-page 4-byte data is latched in the internal address/data latch circuit.

## (5) Page write mode

After a 1-page 4-byte address and data are latched by the page data latch mode, a page write is executed by applying a 0.1-ms program pulse (active-low) to the  $\overrightarrow{PGM}$  pin while  $\overrightarrow{CE}$ =H and  $\overrightarrow{OE}$ =H. After this, program verification can be performed by setting  $\overrightarrow{CE}$  to L and  $\overrightarrow{OE}$  to L.

If programming is not performed by one program pulse, repeated write and verify operations are executed X times (X  $\leq$  10).

#### (6) Byte write mode

A byte write is executed by applying a 0.1-ms program pulse (active-low) to the  $\overline{PGM}$  pin while  $\overline{CE}$ =L and  $\overline{OE}$ =H. After this, program verification can be performed by setting  $\overline{OE}$  to L.

If programming is not performed by one program pulse, repeated write and verify operations are executed X times (X  $\leq$  10).

## (7) Program verify mode

Setting  $\overline{CE}$  to L,  $\overline{PGM}$  to H, and  $\overline{OE}$  to L sets the program verify mode. After writing is performed, this mode should be used to check whether the data was written correctly.

#### (8) Program inhibit mode

The program inhibit mode is used when the  $\overline{OE}$  pins, VPP pins and pins D0 to D7 of multiple  $\mu$ PD78P083s are connected in parallel and any one of these devices must be written to.

The page write mode or byte write mode described above is used to perform a write. At this time, the write is not performed on the device which has the  $\overline{PGM}$  pin driven high.

## 15.2.2 PROM write procedure



Figure 15-2. Page Program Mode Flowchart



Figure 15-3. Page Program Mode Timing



Figure 15-4. Byte Program Mode Flowchart



## Figure 15-5. Byte Program Mode Timing

Cautions 1. Be sure to apply VDD before applying VPP, and remove it after removing VPP.

- 2. VPP must not exceed +13.5 V including overshoot voltage.
- 3. Disconnecting/inserting the device from/to the on-board socket while +12.5 V is being applied to the VPP pin may have an adverse affect on device reliability.

#### 15.2.3 PROM reading procedure

PROM contents can be read onto the external data bus (D0 to D7) using the following procedure.

- (1) Fix the RESET pin low, and supply +5 V to the VPP pin. Unused pins are handled as shown in paragraph,
   (2) "PROM programming mode" in section 1.5 Pin Configuration (Top View).
- (2) Supply +5 V to the VDD and VPP pins.
- (3) Input the address of data to be read to pins A0 through A14.
- (4) Read mode is entered.
- (5) Data is output to pins D0 through D7.

The timing for steps (2) through (5) above is shown in Figure 15-6.



Figure 15-6. PROM Read Timing

## 15.3 Erasure Procedure (μPD78P083DU Only)

With the  $\mu$ PD78P083DU, it is possible to erase (or set all contents to FFH) the data contents written in the program memory, and rewrite the memory.

The data can be erased by exposing the window to light with a wavelength of approximately 400 nm or shorter. Typically, data is erased by 254-nm ultraviolet light rays. The minimum lighting level to completely erase the written data is shown below.

- .
- UV intensity × exposure time: 30 W·s/cm<sup>2</sup> or more
- Exposure time: 40 minutes or more (using a 12 mW/cm<sup>2</sup> ultraviolet lamp. A longer exposure time may be required in case of deterioration of the ultraviolet lamp or dirt on the package window).

When erasing written data, remove any filter on the window and place the device within 2.5 cm of the lamp tube.

#### 15.4 Opaque Film Masking the Window (µPD78P083DU Only)

To prevent unintentional erasure of the EPROM contents by light and to prevent internal circuits from mulfunction due to light coming in through the erasure window, mask the window with opaque film after writing the EPROM.

#### 15.5 Screening of One-Time PROM Versions

One-time PROM versions ( $\mu$ PD78P083CU, 78P083GB-3B4, 78P083GB-3-MTX) cannot be fully tested by NEC before shipment due to the structure of one-time PROM. Therefore, after users have written data into the PROM, screening should be implemented by user: that is, store devices at high temperature for one day as specified below, and verify their contents after the devices have returned to room temperature.

| Storage Temperature | Storage Time |
|---------------------|--------------|
| 125°C               | 24 hours     |

★ For users who do not wish to implement screening by themselves, NEC provides such users with a charged service in which NEC performs a series of processes from writing one-time PROMs and screening them to verifying their contents for users by request. The PROM version devices which provide this service are called QTOP<sup>TM</sup> microcontrollers. As regards the µPD78P083, preparations are underway. For details, please consult an NEC sales representative.

## **CHAPTER 16 INSTRUCTION SET**

This chapter describes each instruction set of the  $\mu$ PD78083 subseries as list table. For details of its operation and operation code, refer to the separate document "**78K/0 series USER'S MANUAL**—Instruction (IEU-1372)."

## 16.1 Legends Used in Operation List

#### 16.1.1 Operand identifiers and description methods

Operands are described in "Operand" column of each instruction in accordance with the description method of the instruction operand identifier (refer to the assembler specifications for detail). When there are two or more description methods, select one of them. Alphabetic letters in capitals and symbols, #, !, \$ and [] are key words and must be described as they are. Each symbol has the following meaning.

- # : Immediate data specification
- ! : Absolute address specification
- \$ : Relative address specification
- []: Indirect address specification

In the case of immediate data, describe an appropriate numeric value or a label. When using a label, be sure to describe the #, !, \$, and [] symbols.

For operand register identifiers, r and rp, either function names (X, A, C, etc.) or absolute names (names in parentheses in the table below, R0, R1, R2, etc.) can be used for description.

| Identifier | Description Method                                                                       |
|------------|------------------------------------------------------------------------------------------|
| r          | X (R0), A (R1), C (R2), B (R3), E (R4), D (R5), L (R6), H (R7),                          |
| rp         | AX (RP0), BC (RP1), DE (RP2), HL (RP3)                                                   |
| sfr        | Special-function register symbol <sup>Note</sup>                                         |
| sfrp       | Special-function register symbol (16-bit manipulatable register even addresses only)Note |
| saddr      | FE20H-FF1FH Immediate data or labels                                                     |
| saddrp     | FE20H-FF1FH Immediate data or labels (even address only)                                 |
| addr16     | 0000H-FFFFH Immediate data or labels                                                     |
|            | (Only even addresses for 16-bit data transfer instructions)                              |
| addr11     | 0800H-0FFFH Immediate data or labels                                                     |
| addr5      | 0040H-007FH Immediate data or labels (even address only)                                 |
| word       | 16-bit immediate data or label                                                           |
| byte       | 8-bit immediate data or label                                                            |
| bit        | 3-bit immediate data or label                                                            |
| RBn        | RB0 to RB3                                                                               |

#### Table 16-1. Operand Identifiers and Description Methods

Note Addresses from FFD0H to FFDFH cannot be accessed with these operands.

Remark For special-function register symbols, refer to Table 3-2 Special-Function Register List.

#### 16.1.2 Description of "operation" column

- A : A register; 8-bit accumulator
- X : X register B : B register C : C register D : D register
- E : E register
- H : H register
- L : L register
- AX : AX register pair; 16-bit accumulator
- BC : BC register pair
- DE : DE register pair
- HL : HL register pair
- PC : Program counter
- SP : Stack pointer
- PSW : Program status word
- CY : Carry flag
- AC : Auxiliary carry flag
- Z : Zero flag
- RBS : Register bank select flag
- IE : Interrupt request enable flag
- NMIS : Non-maskable interrupt servicing flag
- () : Memory contents indicated by address or register contents in parentheses
- $\times_{H},\,\times_{L}~$  : Higher 8 bits and lower 8 bits of 16-bit register
- $\wedge$  : Logical product (AND)
- $_{\vee}$  : Logical sum (OR)
- $\forall$  : Exclusive logical sum (exclusive OR)
- ---- : Inverted data
- addr16: 16-bit immediate data or label
- jdisp8 : Signed 8-bit data (displacement value)

#### 16.1.3 Description of "flag operation" column

- (Blank): Nt affected
- 0 : Cleared to 0
- 1 : Set to 1
- $\times$  : Set/cleared according to the result
- R : Previously saved value is restored

## 16.2 Operation List

| Instruction | , Mnemonic Ope<br>r, #byte<br>saddr, #byte<br>A, r<br>r, A<br>A, saddr<br>saddr, A<br>A, saddr<br>saddr, A<br>A, sfr<br>sfr, A<br>A, laddr16<br>laddr16, A<br>PSW, #byte<br>A, PSW<br>PSW, A |                | _    | С      | lock   |                                 |   | Flag | g  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------|--------|--------|---------------------------------|---|------|----|
| Group       | Mnemonic                                                                                                                                                                                     | Operands       | Byte | Note 1 | Note 2 | Operation                       | z | AC   | CY |
|             |                                                                                                                                                                                              | r, #byte       | 2    | 4      | _      | r ← byte                        |   |      |    |
|             |                                                                                                                                                                                              | saddr, #byte   | 3    | 6      | 7      | (saddr) ← byte                  |   |      |    |
|             |                                                                                                                                                                                              | sfr, #byte     | 3    | -      | 7      | $sfr \leftarrow byte$           |   |      |    |
|             |                                                                                                                                                                                              | A, r Note 3    | 1    | 2      | -      | $A \leftarrow r$                |   |      |    |
|             |                                                                                                                                                                                              | r, A Note 3    | 1    | 2      | -      | $r \leftarrow A$                |   |      |    |
|             |                                                                                                                                                                                              | A, saddr       | 2    | 4      | 5      | $A \leftarrow (saddr)$          |   |      |    |
|             |                                                                                                                                                                                              | saddr, A       | 2    | 4      | 5      | $(saddr) \leftarrow A$          |   |      |    |
|             |                                                                                                                                                                                              | A, sfr         | 2    | -      | 5      | $A \gets sfr$                   |   |      |    |
|             |                                                                                                                                                                                              | sfr, A         | 2    | -      | 5      | $sfr \leftarrow A$              |   |      |    |
|             |                                                                                                                                                                                              | A, !addr16     | 3    | 8      | 9      | $A \leftarrow (addr16)$         |   |      |    |
|             |                                                                                                                                                                                              | !addr16, A     | 3    | 8      | 9      | (addr16) ← A                    |   |      |    |
|             |                                                                                                                                                                                              | PSW, #byte     | 3    | -      | 7      | PSW ← byte                      | × | ×    | ×  |
|             |                                                                                                                                                                                              | A, PSW         | 2    | -      | 5      | $A \leftarrow PSW$              |   |      |    |
|             | MOV                                                                                                                                                                                          | PSW, A         | 2    | -      | 5      | $PSW \leftarrow A$              | × | ×    | ×  |
|             |                                                                                                                                                                                              | A, [DE]        | 1    | 4      | 5      | $A \leftarrow (DE)$             |   |      |    |
| 8-bit data  |                                                                                                                                                                                              | [DE], A        | 1    | 4      | 5      | $(DE) \leftarrow A$             |   |      |    |
| transfer    |                                                                                                                                                                                              | A, [HL]        | 1    | 4      | 5      | $A \leftarrow (HL)$             |   |      |    |
|             |                                                                                                                                                                                              | [HL], A        | 1    | 4      | 5      | $(HL) \leftarrow A$             |   |      |    |
|             |                                                                                                                                                                                              | A, [HL + byte] | 2    | 8      | 9      | $A \leftarrow (HL + byte)$      |   |      |    |
|             |                                                                                                                                                                                              | [HL + byte], A | 2    | 8      | 9      | $(HL + byte) \leftarrow A$      |   |      |    |
|             |                                                                                                                                                                                              | A, [HL + B]    | 1    | 6      | 7      | $A \leftarrow (HL + B)$         |   |      |    |
|             |                                                                                                                                                                                              | [HL + B], A    | 1    | 6      | 7      | $(HL + B) \leftarrow A$         |   |      |    |
|             |                                                                                                                                                                                              | A, [HL + C]    | 1    | 6      | 7      | $A \gets (HL + C)$              |   |      |    |
|             |                                                                                                                                                                                              | [HL + C], A    | 1    | 6      | 7      | $(HL + C) \leftarrow A$         |   |      |    |
|             |                                                                                                                                                                                              | A, r Note 3    | 1    | 2      | -      | $A \leftrightarrow r$           |   |      |    |
|             |                                                                                                                                                                                              | A, saddr       | 2    | 4      | 6      | $A \leftrightarrow (saddr)$     |   |      |    |
|             |                                                                                                                                                                                              | A, sfr         | 2    | -      | 6      | $A \leftrightarrow sfr$         |   |      |    |
|             |                                                                                                                                                                                              | A, !addr16     | 3    | 8      | 10     | $A \leftrightarrow (addr16)$    |   |      |    |
|             | хсн                                                                                                                                                                                          | A, [DE]        | 1    | 4      | 6      | $A \leftrightarrow (DE)$        |   |      |    |
|             |                                                                                                                                                                                              | A, [HL]        | 1    | 4      | 6      | $A \leftrightarrow (HL)$        |   |      |    |
|             | хсн                                                                                                                                                                                          | A, [HL + byte] | 2    | 8      | 10     | $A \leftrightarrow (HL + byte)$ |   |      |    |
|             |                                                                                                                                                                                              | A, [HL + B]    | 2    | 8      | 10     | $A \leftrightarrow (HL + B)$    |   |      |    |
|             |                                                                                                                                                                                              | A, [HL + C]    | 2    | 8      | 10     | $A \leftrightarrow (HL + C)$    |   |      |    |

Notes 1. When the internal high-speed RAM area is accessed or instruction with no data access

2. When an area except the internal high-speed RAM area is accessed.

3. Except "r = A"

| Instruction    |          |                |      | C      | lock   |                                              |   | Fla | g  |
|----------------|----------|----------------|------|--------|--------|----------------------------------------------|---|-----|----|
| Group          | Mnemonic | Operands       | Byte | Note 1 | Note 2 | Operation                                    | Z | AC  | CY |
|                |          | rp, #word      | 3    | 6      | -      | $rp \leftarrow word$                         |   |     |    |
|                |          | saddrp, #word  | 4    | 8      | 10     | $(saddrp) \leftarrow word$                   |   |     |    |
|                |          | sfrp, #word    | 4    | -      | 10     | $sfrp \leftarrow word$                       |   |     |    |
|                |          | AX, saddrp     | 2    | 6      | 8      | $AX \leftarrow (saddrp)$                     |   |     |    |
| 10 64          |          | saddrp, AX     | 2    | 6      | 8      | $(saddrp) \leftarrow AX$                     |   |     |    |
| 16-bit<br>data | MOVW     | AX, sfrp       | 2    | -      | 8      | $AX \leftarrow sfrp$                         |   |     |    |
| transfer       |          | sfrp, AX       | 2    | -      | 8      | $sfrp \leftarrow AX$                         |   |     |    |
|                |          | AX, rp Note 3  | 1    | 4      | -      | AX ← rp                                      |   |     |    |
|                |          | rp, AX Note 3  | 1    | 4      | -      | $rp \leftarrow AX$                           |   |     |    |
|                |          | AX, !addr16    | 3    | 10     | 12     | $AX \leftarrow (addr16)$                     |   |     |    |
|                |          | !addr16, AX    | 3    | 10     | 12     | $(addr16) \leftarrow AX$                     |   |     |    |
|                | хснw     | AX, rp Note 3  | 1    | 4      | -      | $AX \leftrightarrow rp$                      |   |     |    |
|                |          | A, #byte       | 2    | 4      | -      | A, CY $\leftarrow$ A + byte                  | × | ×   | ×  |
|                |          | saddr, #byte   | 3    | 6      | 8      | (saddr), CY $\leftarrow$ (saddr) + byte      | × | ×   | ×  |
|                |          | A, r Note 4    | 2    | 4      | _      | A, CY $\leftarrow$ A + r                     | × | ×   | ×  |
|                |          | r, A           | 2    | 4      | _      | $r, CY \leftarrow r + A$                     | × | ×   | ×  |
|                | ADD      | A, saddr       | 2    | 4      | 5      | A, CY $\leftarrow$ A + (saddr)               | × | ×   | ×  |
|                |          | A, !addr16     | 3    | 8      | 9      | A, CY $\leftarrow$ A + (addr16)              | × | ×   | ×  |
|                |          | A, [HL]        | 1    | 4      | 5      | A, CY $\leftarrow$ A + (HL)                  | × | ×   | ×  |
|                |          | A, [HL + byte] | 2    | 8      | 9      | A, CY $\leftarrow$ A + (HL + byte)           | × | ×   | ×  |
|                |          | A, [HL + B]    | 2    | 8      | 9      | A, CY $\leftarrow$ A + (HL + B)              | × | ×   | ×  |
| 8-bit          |          | A, [HL + C]    | 2    | 8      | 9      | A, CY $\leftarrow$ A + (HL + C)              | × | ×   | ×  |
| operation      |          | A, #byte       | 2    | 4      | -      | A, CY $\leftarrow$ A + byte + CY             | × | ×   | ×  |
|                |          | saddr, #byte   | 3    | 6      | 8      | (saddr), CY $\leftarrow$ (saddr) + byte + CY | × | ×   | ×  |
|                |          | A, r Note 4    | 2    | 4      | _      | $A,CY \gets A + r + CY$                      | × | ×   | ×  |
|                |          | r, A           | 2    | 4      | _      | $r,CY \leftarrow r + A + CY$                 | × | ×   | ×  |
|                | ADDC     | A, saddr       | 2    | 4      | 5      | A, CY $\leftarrow$ A + (saddr) + CY          | × | ×   | ×  |
|                | ADDC     | A, !addr16     | 3    | 8      | 9      | A, CY $\leftarrow$ A + (addr16) + CY         | × | ×   | ×  |
|                |          | A, [HL]        | 1    | 4      | 5      | $A,CY\leftarrowA+(HL)+CY$                    | × | ×   | ×  |
|                |          | A, [HL + byte] | 2    | 8      | 9      | A, CY $\leftarrow$ A + (HL + byte) + CY      | × | ×   | ×  |
|                |          | A, [HL + B]    | 2    | 8      | 9      | $A,CY\leftarrowA+(HL+B)+CY$                  | × | ×   | ×  |
|                |          | A, [HL + C]    | 2    | 8      | 9      | $A,CY\leftarrowA+(HL+C)+CY$                  | × | ×   | ×  |

2. When an area except the internal high-speed RAM area is accessed

**3.** Only when rp = BC, DE or HL

4. Except "r = A"

| Instruction |          |                |      | С      | lock   |                                              |   | Flag | <u>д</u> |
|-------------|----------|----------------|------|--------|--------|----------------------------------------------|---|------|----------|
| Group       | Mnemonic | Operands       | Byte | Note 1 | Note 2 | - Operation                                  | z | AC   | CY       |
|             |          | A, #byte       | 2    | 4      | -      | A, CY $\leftarrow$ A – byte                  | × | ×    | Х        |
|             |          | saddr, #byte   | 3    | 6      | 8      | (saddr), CY $\leftarrow$ (saddr) – byte      | × | ×    | ×        |
|             |          | A, r Note 3    | 2    | 4      | -      | A, CY $\leftarrow$ A - r                     | × | ×    | ×        |
|             |          | r, A           | 2    | 4      | _      | $r, CY \leftarrow r - A$                     | × | ×    | ×        |
|             |          | A, saddr       | 2    | 4      | 5      | A, CY $\leftarrow$ A – (saddr)               | × | ×    | ×        |
|             | SUB      | A, !addr16     | 3    | 8      | 9      | A, CY $\leftarrow$ A – (addr16)              | × | ×    | ×        |
|             |          | A, [HL]        | 1    | 4      | 5      | A, CY $\leftarrow$ A – (HL)                  | × | ×    | ×        |
|             |          | A, [HL + byte] | 2    | 8      | 9      | A, CY $\leftarrow$ A – (HL + byte)           | × | ×    | ×        |
|             |          | A, [HL + B]    | 2    | 8      | 9      | A, CY $\leftarrow$ A – (HL + B)              | × | ×    | ×        |
|             |          | A, [HL + C]    | 2    | 8      | 9      | $A,CY\leftarrowA-(HL+C)$                     | × | ×    | ×        |
|             |          | A, #byte       | 2    | 4      | _      | A, CY $\leftarrow$ A – byte – CY             | × | ×    | ×        |
|             |          | saddr, #byte   | 3    | 6      | 8      | (saddr), $CY \leftarrow (saddr) - byte - CY$ | × | ×    | ×        |
|             |          | A, r Note 3    | 2    | 4      | -      | $A,CY\leftarrowA-r-CY$                       | × | ×    | ×        |
|             |          | r, A           | 2    | 4      | -      | $r,CY\leftarrowr-A-CY$                       | × | ×    | ×        |
| 8-bit       | SUBC     | A, saddr       | 2    | 4      | 5      | A, CY $\leftarrow$ A – (saddr) – CY          | × | ×    | ×        |
| operation   | 3060     | A, !addr16     | 3    | 8      | 9      | A, CY $\leftarrow$ A – (addr16) – CY         | × | ×    | ×        |
|             |          | A, [HL]        | 1    | 4      | 5      | $A,CY\leftarrowA-(HL)-CY$                    | × | ×    | ×        |
|             |          | A, [HL + byte] | 2    | 8      | 9      | A, CY $\leftarrow$ A – (HL + byte) – CY      | × | ×    | ×        |
|             |          | A, [HL + B]    | 2    | 8      | 9      | $A,CY\leftarrowA-(HL+B)-CY$                  | × | ×    | ×        |
|             |          | A, [HL + C]    | 2    | 8      | 9      | $A,CY\leftarrowA-(HL+C)-CY$                  | × | ×    | ×        |
|             |          | A, #byte       | 2    | 4      | -      | $A \leftarrow A \land byte$                  | × |      |          |
|             |          | saddr, #byte   | 3    | 6      | 8      | $(saddr) \leftarrow (saddr) \land byte$      | × |      |          |
|             |          | A, r Note 3    | 2    | 4      | -      | $A \leftarrow A \wedge r$                    | × |      |          |
|             |          | r, A           | 2    | 4      | -      | $r \leftarrow r \land A$                     | × |      |          |
|             | AND      | A, saddr       | 2    | 4      | 5      | $A \leftarrow A \land (saddr)$               | × |      |          |
|             |          | A, !addr16     | 3    | 8      | 9      | $A \leftarrow A \land (addr16)$              | × |      |          |
|             |          | A, [HL]        | 1    | 4      | 5      | $A \leftarrow A \land (HL)$                  | × |      |          |
|             |          | A, [HL + byte] | 2    | 8      | 9      | $A \leftarrow A \land (HL + byte)$           | × |      |          |
|             |          | A, [HL + B]    | 2    | 8      | 9      | $A \leftarrow A \land (HL + B)$              | × |      |          |
|             |          | A, [HL + C]    | 2    | 8      | 9      | $A \leftarrow A \land (HL + C)$              | × |      |          |

2. When an area except the internal high-speed RAM area is accessed

3. Except "r = A"

| Instruction |                            |                |      | C      | lock   | 0                                         |   | Flag | y  |
|-------------|----------------------------|----------------|------|--------|--------|-------------------------------------------|---|------|----|
| Group       | Minemonic                  | Operands       | Byte | Note 1 | Note 2 | Operation                                 | Z | AC   | CY |
|             |                            | A, #byte       | 2    | 4      | -      | $A \leftarrow A \lor byte$                | × |      |    |
|             | Group Mnemonic<br>OR<br>OR | saddr, #byte   | 3    | 6      | 8      | $(saddr) \leftarrow (saddr) \lor byte$    | × |      |    |
|             |                            | A, r Note 3    | 2    | 4      | -      | $A \leftarrow A \lor r$                   | × |      |    |
|             |                            | r, A           | 2    | 4      | -      | $r \leftarrow r \lor A$                   | × |      |    |
|             | 0.5                        | A, saddr       | 2    | 4      | 5      | $A \leftarrow A \lor$ (saddr)             | × |      |    |
|             | OR                         | A, !addr16     | 3    | 8      | 9      | $A \leftarrow A \lor (addr16)$            | × |      |    |
|             |                            | A, [HL]        | 1    | 4      | 5      | $A \leftarrow A \lor (HL)$                | × |      |    |
|             |                            | A, [HL + byte] | 2    | 8      | 9      | $A \leftarrow A \lor (HL + byte)$         | × |      |    |
|             |                            | A, [HL + B]    | 2    | 8      | 9      | $A \leftarrow A \lor (HL + B)$            | × |      |    |
|             |                            | A, [HL + C]    | 2    | 8      | 9      | $A \leftarrow A \lor (HL + C)$            | × |      |    |
|             |                            | A, #byte       | 2    | 4      | _      | $A \leftarrow A \forall$ byte             | × |      |    |
|             |                            | saddr, #byte   | 3    | 6      | 8      | $(saddr) \leftarrow (saddr) \forall byte$ | × |      |    |
|             |                            | A, r Note 3    | 2    | 4      | -      | $A \leftarrow A \forall r$                | × |      |    |
|             | XOR                        | r, A           | 2    | 4      | _      | $r \leftarrow r \forall A$                | × |      |    |
| 8-bit       | VOR                        | A, saddr       | 2    | 4      | 5      | $A \leftarrow A \forall$ (saddr)          | × |      |    |
| operation   | AUK                        | A, !addr16     | 3    | 8      | 9      | $A \leftarrow A \forall$ (addr16)         | × |      |    |
|             |                            | A, [HL]        | 1    | 4      | 5      | $A \leftarrow A \forall (HL)$             | × |      |    |
|             |                            | A, [HL + byte] | 2    | 8      | 9      | $A \leftarrow A \forall$ (HL + byte)      | × |      |    |
|             |                            | A, [HL + B]    | 2    | 8      | 9      | $A \leftarrow A \forall (HL + B)$         | × |      |    |
|             |                            | A, [HL + C]    | 2    | 8      | 9      | $A \leftarrow A \not \forall (HL + C)$    | × |      |    |
|             |                            | A, #byte       | 2    | 4      | _      | A – byte                                  | × | ×    | ×  |
|             |                            | saddr, #byte   | 3    | 6      | 8      | (saddr) – byte                            | × | ×    | ×  |
|             |                            | A, r Note 3    | 2    | 4      | _      | A – r                                     | × | ×    | ×  |
|             |                            | r, A           | 2    | 4      | _      | r – A                                     | × | ×    | ×  |
|             | CMD                        | A, saddr       | 2    | 4      | 5      | A – (saddr)                               | × | ×    | ×  |
|             | CIVIF                      | A, !addr16     | 3    | 8      | 9      | A – (addr16)                              | × | ×    | ×  |
|             |                            | A, [HL]        | 1    | 4      | 5      | A – (HL)                                  | × | ×    | ×  |
|             |                            | A, [HL + byte] | 2    | 8      | 9      | A – (HL + byte)                           | × | ×    | ×  |
|             |                            | A, [HL + B]    | 2    | 8      | 9      | A – (HL + B)                              | × | ×    | ×  |
|             |                            | A, [HL + C]    | 2    | 8      | 9      | A – (HL + C)                              | × | ×    | ×  |

2. When an area except the internal high-speed RAM area is accessed

3. Except "r = A"

| Instruction         | Maamania | Onerende      | Dute | c      | lock   | Operation                                                                                                                                         |   | Flag | J  |
|---------------------|----------|---------------|------|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------|---|------|----|
| Group               | Mnemonic | Operands      | Byte | Note 1 | Note 2 | Operation                                                                                                                                         | Z | AC   | С١ |
|                     | ADDW     | AX, #word     | 3    | 6      | _      | AX, CY $\leftarrow$ AX + word                                                                                                                     | × | ×    | ×  |
| 16-bit<br>operation | SUBW     | AX, #word     | 3    | 6      | _      | AX, CY $\leftarrow$ AX – word                                                                                                                     | × | ×    | ×  |
| operation           | CMPW     | AX, #word     | 3    | 6      | _      | AX – word                                                                                                                                         | × | ×    | ×  |
| Multiply/           | MULU     | X             | 2    | 16     | _      | $AX \leftarrow A \times X$                                                                                                                        |   |      | -  |
| divide              | DIVUW    | С             | 2    | 25     | _      | AX (Quotient), C (Remainder) $\leftarrow$ AX $\div$ C                                                                                             |   |      |    |
|                     | INC      | r             | 1    | 2      | _      | r ← r + 1                                                                                                                                         | × | ×    |    |
|                     | INC      | saddr         | 2    | 4      | 6      | $(saddr) \leftarrow (saddr) + 1$                                                                                                                  | × | ×    |    |
| Increment/          | DEC      | r             | 1    | 2      | _      | $r \leftarrow r - 1$                                                                                                                              | × | ×    |    |
| decrement           | DEC      | saddr         | 2    | 4      | 6      | $(saddr) \leftarrow (saddr) - 1$                                                                                                                  | × | ×    |    |
|                     | INCW     | rp            | 1    | 4      | _      | $rp \leftarrow rp + 1$                                                                                                                            |   |      |    |
|                     | DECW     | rp            | 1    | 4      | _      | $rp \leftarrow rp - 1$                                                                                                                            |   |      |    |
|                     | ROR      | A, 1          | 1    | 2      | -      | $(CY, A_7 \leftarrow A_0, A_{m-1} \leftarrow A_m) \times 1 \text{ time}$ $(CY, A_0 \leftarrow A_7, A_{m+1} \leftarrow A_m) \times 1 \text{ time}$ |   |      | ×  |
|                     | ROL      | A, 1          | 1    | 2      | _      | $(CY, A_0 \leftarrow A_7, A_{m+1} \leftarrow A_m) \times 1$ time                                                                                  |   |      | ×  |
|                     | RORC     | A, 1          | 1    | 2      | -      | $(CY \leftarrow A_0, A_7 \leftarrow CY, A_{m-1} \leftarrow A_m) \times 1 \text{ time}$                                                            |   |      | ×  |
| Rotate              | ROLC     | A, 1          | 1    | 2      | _      | $(CY \leftarrow A_7, A_0 \leftarrow CY, A_{m+1} \leftarrow A_m) \times 1 \text{ time}$                                                            |   |      | ×  |
|                     | ROR4     | [HL]          | 2    | 10     | 12     | $A_{3-0} \leftarrow (HL)_{3-0}, (HL)_{7-4} \leftarrow A_{3-0}, (HL)_{3-0} \leftarrow (HL)_{7-4}$                                                  |   |      |    |
|                     | ROL4     | [HL]          | 2    | 10     | 12     | $A_{3-0} \leftarrow (HL)_{7-4}, (HL)_{3-0} \leftarrow A_{3-0}, \\ (HL)_{7-4} \leftarrow (HL)_{3-0}$                                               |   |      |    |
| BCD                 | ADJBA    |               | 2    | 4      | -      | Decimal Adjust Accumulator after<br>Addition                                                                                                      | × | ×    | ×  |
| adjust              | ADJBS    |               | 2    | 4      | _      | Decimal Adjust Accumulator after<br>Subtract                                                                                                      | × | ×    | ×  |
|                     |          | CY, saddr.bit | 3    | 6      | 7      | $CY \leftarrow (saddr.bit)$                                                                                                                       |   |      | ×  |
|                     |          | CY, sfr.bit   | 3    | -      | 7      | $CY \leftarrow sfr.bit$                                                                                                                           |   |      | ×  |
|                     |          | CY, A.bit     | 2    | 4      | -      | $CY \leftarrow A.bit$                                                                                                                             |   |      | ×  |
|                     |          | CY, PSW.bit   | 3    | -      | 7      | $CY \leftarrow PSW.bit$                                                                                                                           |   |      | ×  |
| Bit                 |          | CY, [HL].bit  | 2    | 6      | 7      | $CY \leftarrow (HL).bit$                                                                                                                          |   |      | ×  |
| manipu-<br>late     | MOV1     | saddr.bit, CY | 3    | 6      | 8      | $(saddr.bit) \leftarrow CY$                                                                                                                       |   |      |    |
| iuto                |          | sfr.bit, CY   | 3    | -      | 8      | $sfr.bit \leftarrow CY$                                                                                                                           |   |      |    |
|                     |          | A.bit, CY     | 2    | 4      | _      | A.bit ← CY                                                                                                                                        |   |      |    |
|                     |          | PSW.bit, CY   | 3    | -      | 8      | $PSW.bit \leftarrow CY$                                                                                                                           | × | ×    |    |
|                     |          | [HL].bit, CY  | 2    | 6      | 8      | (HL).bit $\leftarrow$ CY                                                                                                                          |   |      |    |

2. When an area except the internal high-speed RAM area is accessed

| Instruction |          |               |      | C      | lock   |                                            | F | lag  |
|-------------|----------|---------------|------|--------|--------|--------------------------------------------|---|------|
| Group       | Mnemonic | Operands      | Byte | Note 1 | Note 2 | - Operation                                | Z | ACCY |
|             |          | CY, saddr.bit | 3    | 6      | 7      | $CY \leftarrow CY \land (saddr.bit)$       |   | ×    |
|             |          | CY, sfr.bit   | 3    | -      | 7      | $CY \leftarrow CY \land sfr.bit$           |   | ×    |
|             | AND1     | CY, A.bit     | 2    | 4      | _      | $CY \leftarrow CY \land A.bit$             |   | ×    |
|             |          | CY, PSW.bit   | 3    | -      | 7      | $CY \leftarrow CY \land PSW.bit$           |   | ×    |
|             |          | CY, [HL].bit  | 2    | 6      | 7      | $CY \leftarrow CY \land (HL).bit$          |   | ×    |
|             |          | CY, saddr.bit | 3    | 6      | 7      | $CY \leftarrow CY \lor (saddr.bit)$        |   | ×    |
|             |          | CY, sfr.bit   | 3    | -      | 7      | $CY \leftarrow CY \lor sfr.bit$            |   | ×    |
|             | OR1      | CY, A.bit     | 2    | 4      | _      | $CY \leftarrow CY \lor A.bit$              |   | ×    |
|             |          | CY, PSW.bit   | 3    | -      | 7      | $CY \leftarrow CY \lor PSW.bit$            |   | ×    |
|             |          | CY, [HL].bit  | 2    | 6      | 7      | $CY \leftarrow CY \lor (HL).bit$           |   | ×    |
|             |          | CY, saddr.bit | 3    | 6      | 7      | $CY \leftarrow CY \forall (saddr.bit)$     |   | ×    |
|             |          | CY, sfr.bit   | 3    | -      | 7      | $CY \leftarrow CY  \forall  sfr.bit$       |   | ×    |
| Bit         | XOR1     | CY, A.bit     | 2    | 4      | _      | $CY \leftarrow CY \forall A.bit$           |   | ×    |
| manipu-     |          | CY, PSW. bit  | 3    | -      | 7      | $CY \leftarrow CY \forall PSW.bit$         |   | ×    |
| late        |          | CY, [HL].bit  | 2    | 6      | 7      | $CY \leftarrow CY \not\leftarrow (HL).bit$ |   | ×    |
|             |          | saddr.bit     | 2    | 4      | 6      | $(saddr.bit) \leftarrow 1$                 |   |      |
|             |          | sfr.bit       | 3    | -      | 8      | sfr.bit $\leftarrow$ 1                     |   |      |
|             | SET1     | A.bit         | 2    | 4      | -      | A.bit $\leftarrow$ 1                       |   |      |
|             |          | PSW.bit       | 2    | -      | 6      | $PSW.bit \gets 1$                          | × | × ×  |
|             |          | [HL].bit      | 2    | 6      | 8      | (HL).bit $\leftarrow$ 1                    |   |      |
|             |          | saddr.bit     | 2    | 4      | 6      | $(saddr.bit) \leftarrow 0$                 |   |      |
|             |          | sfr.bit       | 3    | -      | 8      | sfr.bit $\leftarrow 0$                     |   |      |
|             | CLR1     | A.bit         | 2    | 4      | -      | A.bit $\leftarrow 0$                       |   |      |
|             |          | PSW.bit       | 2    | -      | 6      | $PSW.bit \gets 0$                          | × | × ×  |
|             |          | [HL].bit      | 2    | 6      | 8      | (HL).bit $\leftarrow 0$                    |   |      |
|             | SET1     | CY            | 1    | 2      | -      | $CY \leftarrow 1$                          |   | 1    |
|             | CLR1     | CY            | 1    | 2      | -      | $CY \leftarrow 0$                          |   | 0    |
|             | NOT1     | CY            | 1    | 2      | -      | $CY \leftarrow \overline{CY}$              |   | ×    |

 $\ensuremath{\mathbf{2}}.$  When an area except the internal high-speed RAM area is accessed

| Instruction     |          | On a new da | Duta | С      | lock   | Quanting                                                                                                                                                                                                              |   | Flag | у<br>ј |
|-----------------|----------|-------------|------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------|--------|
| Group           | Mnemonic | Operands    | Byte | Note 1 | Note 2 | Operation                                                                                                                                                                                                             | Z | AC   | CY     |
|                 | CALL     | !addr16     | 3    | 7      | -      | $ \begin{array}{l} (SP-1) \leftarrow (PC+3) \shortparallel, \ (SP-2) \leftarrow (PC+3) \shortparallel, \\ PC \leftarrow addr16, \ SP \leftarrow SP-2 \end{array} $                                                    |   |      |        |
|                 | CALLF    | !addr11     | 2    | 5      | -      | $ \begin{array}{l} (SP-1) \leftarrow (PC+2)_{H},  (SP-2) \leftarrow (PC+2)_{L}, \\ PC_{15-11} \leftarrow 00001,  PC_{10-0} \leftarrow addr11, \\ SP \leftarrow SP-2 \end{array} $                                     |   |      |        |
|                 | CALLT    | [addr5]     | 1    | 6      | _      | $\begin{array}{l} (SP-1) \leftarrow (PC+1)_{H,} \; (SP-2) \leftarrow (PC+1)_{L,} \\ PC_{H} \leftarrow (00000000, \; addr5+1), \\ PC_{L} \leftarrow (00000000, \; addr5), \\ SP \leftarrow SP-2 \end{array}$           |   |      |        |
| Call/return     | BRK      |             | 1    | 6      | _      | $\begin{array}{l} (SP-1) \leftarrow PSW,  (SP-2) \leftarrow (PC+1)_{H,} \\ (SP-3) \leftarrow (PC+1)_{L},  PC_{H} \leftarrow (003FH), \\ PC_{L} \leftarrow (003EH),  SP \leftarrow SP-3,  IE \leftarrow 0 \end{array}$ |   |      |        |
|                 | RET      |             | 1    | 6      | -      | $PC_{H} \leftarrow (SP + 1), PC_{L} \leftarrow (SP),$<br>$SP \leftarrow SP + 2$                                                                                                                                       |   |      |        |
|                 | RETI     |             | 1    | 6      | -      | $\begin{array}{l} PC_{H} \leftarrow (SP+1), \ PC_{L} \leftarrow (SP), \\ PSW \leftarrow (SP+2), \ SP \leftarrow SP+3, \\ NMIS \leftarrow 0 \end{array}$                                                               | R | R    | R      |
|                 | RETB     |             | 1    | 6      | _      | $\begin{array}{l} PC_{H} \leftarrow (SP+1),  PC_{L} \leftarrow (SP), \\ PSW \leftarrow (SP+2),  SP \leftarrow SP+3 \end{array}$                                                                                       | R | R    | R      |
|                 |          | PSW         | 1    | 2      | -      | $(SP - 1) \leftarrow PSW, SP \leftarrow SP - 1$                                                                                                                                                                       |   |      |        |
|                 | PUSH     | rp          | 1    | 4      | -      | $(SP - 1) \leftarrow rp_H, (SP - 2) \leftarrow rp_L, SP \leftarrow SP - 2$                                                                                                                                            |   |      |        |
| Stack           |          | PSW         | 1    | 2      | _      | $PSW \leftarrow (SP),  SP \leftarrow SP + 1$                                                                                                                                                                          | R | R    | R      |
| manipu-<br>late | POP      | rp          | 1    | 4      | _      | $r_{PH} \leftarrow (SP + 1), r_{PL} \leftarrow (SP),$<br>$SP \leftarrow SP + 2$                                                                                                                                       |   |      |        |
|                 |          | SP, #word   | 4    | -      | 10     | $SP \leftarrow word$                                                                                                                                                                                                  |   |      |        |
|                 | MOVW     | SP, AX      | 2    | -      | 8      | $SP \leftarrow AX$                                                                                                                                                                                                    |   |      |        |
|                 |          | AX, SP      | 2    | -      | 8      | $AX \leftarrow SP$                                                                                                                                                                                                    |   |      |        |
| Uncondi-        |          | !addr16     | 3    | 6      | -      | $PC \leftarrow addr16$                                                                                                                                                                                                |   |      |        |
| tional          | BR       | \$addr16    | 2    | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$                                                                                                                                                                                       |   |      |        |
| branch          |          | AX          | 2    | 8      | -      | $PC_{H} \leftarrow A,  PC_{L} \leftarrow X$                                                                                                                                                                           |   |      |        |
|                 | вс       | \$addr16    | 2    | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$ if $CY = 1$                                                                                                                                                                           |   |      |        |
| Conditional     | BNC      | \$addr16    | 2    | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$ if $CY = 0$                                                                                                                                                                           |   |      |        |
| branch          | BZ       | \$addr16    | 2    | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$ if Z = 1                                                                                                                                                                              |   |      |        |
|                 | BNZ      | \$addr16    | 2    | 6      | -      | $PC \leftarrow PC + 2 + jdisp8$ if $Z = 0$                                                                                                                                                                            |   |      |        |

2. When an area except the internal high-speed RAM area is accessed

| Instruction      |          |                     |      | C      | lock   |                                                                               |   | Flag |
|------------------|----------|---------------------|------|--------|--------|-------------------------------------------------------------------------------|---|------|
| Group            | Mnemonic | Operands            | Byte | Note 1 | Note 2 | Operation                                                                     | z | ACCY |
|                  |          | saddr.bit, \$addr16 | 3    | 8      | 9      | $PC \leftarrow PC + 3 + jdisp8 if(saddr.bit) = 1$                             |   |      |
|                  |          | sfr.bit, \$addr16   | 4    | -      | 11     | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 1                                |   |      |
|                  | вт       | A.bit, \$addr16     | 3    | 8      | -      | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 1                                  |   |      |
|                  |          | PSW.bit, \$addr16   | 3    | -      | 9      | $PC \leftarrow PC + 3 + jdisp8$ if PSW.bit = 1                                |   |      |
|                  |          | [HL].bit, \$addr16  | 3    | 10     | 11     | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 1                               |   |      |
|                  |          | saddr.bit, \$addr16 | 4    | 10     | 11     | $PC \leftarrow PC + 4 + jdisp8 if(saddr.bit) = 0$                             |   |      |
|                  |          | sfr.bit, \$addr16   | 4    | -      | 11     | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 0                                |   |      |
|                  | BF       | A.bit, \$addr16     | 3    | 8      | -      | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 0                                  |   |      |
|                  |          | PSW.bit, \$addr16   | 4    | -      | 11     | $PC \leftarrow PC + 4 + jdisp8$ if PSW. bit = 0                               |   |      |
|                  |          | [HL].bit, \$addr16  | 3    | 10     | 11     | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 0                               |   |      |
| Condi-<br>tional |          | saddr.bit, \$addr16 | 4    | 10     | 12     | $PC \leftarrow PC + 4 + jdisp8$<br>if(saddr.bit) = 1<br>then reset(saddr.bit) |   |      |
| branch           |          | sfr.bit, \$addr16   | 4    | _      | 12     | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 1<br>then reset sfr.bit          |   |      |
|                  | BTCLR    | A.bit, \$addr16     | 3    | 8      | -      | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 1<br>then reset A.bit              |   |      |
|                  |          | PSW.bit, \$addr16   | 4    | -      | 12     | $PC \leftarrow PC + 4 + jdisp8$ if PSW.bit = 1<br>then reset PSW.bit          | × | × ×  |
|                  |          | [HL].bit, \$addr16  | 3    | 10     | 12     | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 1<br>then reset (HL).bit        |   |      |
|                  |          | B, \$addr16         | 2    | 6      | _      | B ← B − 1, then<br>PC ← PC + 2 + jdisp8 if B ≠ 0                              |   |      |
|                  | DBNZ     | C, \$addr16         | 2    | 6      | _      | C ← C −1, then<br>PC ← PC + 2 + jdisp8 if C $\neq$ 0                          |   |      |
|                  |          | saddr. \$addr16     | 3    | 8      | 10     | (saddr) ← (saddr) – 1, then<br>PC ← PC + 3 + jdisp8 if(saddr) ≠ 0             |   |      |
|                  | SEL      | RBn                 | 2    | 4      | -      | RBS1, 0 ← n                                                                   |   |      |
|                  | NOP      |                     | 1    | 2      | -      | No Operation                                                                  |   |      |
| CPU              | EI       |                     | 2    | -      | 6      | $IE \leftarrow 1(Enable Interrupt)$                                           |   |      |
| control          | DI       |                     | 2    | -      | 6      | $IE \leftarrow 0(Disable Interrupt)$                                          |   |      |
|                  | HALT     |                     | 2    | 6      | _      | Set HALT Mode                                                                 |   |      |
|                  | STOP     |                     | 2    | 6      | _      | Set STOP Mode                                                                 |   |      |

 $\ensuremath{\textbf{2}}.$  When an area except the internal high-speed RAM area is accessed

## 16.3 Instructions Listed by Addressing Type

## (1) 8-bit instructions

MOV, XCH, ADD, ADDC, SUB, SUBC, AND, OR, XOR, CMP, MULU, DIVUW, INC, DEC, ROR, ROL, RORC, ROLC, ROR4, ROL4, PUSH, POP, DBNZ

| Second Operand                      | #byte                                                        | А                                                    | <sub>r</sub> Note                      | sfr        | saddr                                  | !addr16                                | PSW   | [DE]       | (HL)                                   | [HL + byte]<br>[HL + B]                | \$addr16 | 1                          | None         |
|-------------------------------------|--------------------------------------------------------------|------------------------------------------------------|----------------------------------------|------------|----------------------------------------|----------------------------------------|-------|------------|----------------------------------------|----------------------------------------|----------|----------------------------|--------------|
| First Operand                       | #byte                                                        | ~                                                    |                                        | 511        | 50001                                  |                                        | 1.000 |            | ['''                                   | [HL + C]                               |          |                            | None         |
| A                                   | ADD<br>ADDC<br>SUB<br>SUBC                                   |                                                      | MOV<br>XCH<br>ADD<br>ADDC              | MOV<br>XCH |                                        | MOV<br>XCH<br>ADD<br>ADDC              | MOV   | MOV<br>XCH | MOV<br>XCH<br>ADD<br>ADDC              |                                        |          | ROR<br>ROL<br>RORC<br>ROLC |              |
|                                     | AND<br>OR<br>XOR<br>CMP                                      |                                                      | SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP |            | SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP |       |            | SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP |          |                            |              |
| r                                   | MOV                                                          | MOV<br>ADD<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP |                                        |            |                                        |                                        |       |            |                                        |                                        |          |                            | INC<br>DEC   |
| B, C                                |                                                              |                                                      |                                        |            |                                        |                                        |       |            |                                        |                                        | DBNZ     |                            |              |
| sfr                                 | MOV                                                          | MOV                                                  |                                        |            |                                        |                                        |       |            |                                        |                                        |          |                            |              |
| saddr                               | MOV<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV                                                  |                                        |            |                                        |                                        |       |            |                                        |                                        | DBNZ     |                            | INC<br>DEC   |
| !addr16                             |                                                              | MOV                                                  |                                        |            |                                        |                                        |       |            |                                        |                                        |          |                            |              |
| PSW                                 | MOV                                                          | MOV                                                  |                                        |            |                                        |                                        |       |            |                                        |                                        |          |                            | PUSH<br>POP  |
| [DE]                                |                                                              | MOV                                                  |                                        |            |                                        |                                        |       |            |                                        |                                        |          |                            |              |
| [HL]                                |                                                              | MOV                                                  |                                        |            |                                        |                                        |       |            |                                        |                                        |          |                            | ROR4<br>ROL4 |
| [HL + byte]<br>[HL + B]<br>[HL + C] |                                                              | MOV                                                  |                                        |            |                                        |                                        |       |            |                                        |                                        |          |                            |              |
| Х                                   |                                                              |                                                      |                                        |            |                                        |                                        |       |            |                                        |                                        |          |                            | MULU         |
| С                                   |                                                              |                                                      |                                        |            |                                        |                                        |       |            |                                        |                                        |          |                            | DIVUW        |

Note Except r = A

 $\star$ 

## (2) 16-bit instructions

MOVW, XCHW, ADDW, SUBW, CMPW, PUSH, POP, INCW, DECW

| Second Operand<br>First Operand | #word                | AX       | rp <sup>Note</sup> | sfrp | saddrp | !addr16 | SP   | None                        |
|---------------------------------|----------------------|----------|--------------------|------|--------|---------|------|-----------------------------|
| AX                              | ADDW<br>SUBW<br>CMPW |          | MOVW<br>XCHW       | MOVW | MOVW   | MOVW    | MOVW |                             |
| rp                              | MOVW                 | MOVWNote |                    |      |        |         |      | INCW<br>DECW<br>PUSH<br>POP |
| sfrp                            | MOVW                 | MOVW     |                    |      |        |         |      |                             |
| saddrp                          | MOVW                 | MOVW     |                    |      |        |         |      |                             |
| !addr16                         |                      | MOVW     |                    |      |        |         |      |                             |
| SP                              | MOVW                 | MOVW     |                    |      |        |         |      |                             |

**Note** Only when rp = BC, DE, HL

## (3) Bit manipulation instructions

MOV1, AND1, OR1, XOR1, SET1, CLR1, NOT1, BT, BF, BTCLR

| Second Operand<br>First Operand | A.bit                       | sfr.bit                     | saddr.bit                   | PSW.bit                     | [HL].bit                    | CY   | \$addr16          | None                 |
|---------------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|------|-------------------|----------------------|
| A.bit                           |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| sfr.bit                         |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| saddr.bit                       |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| PSW.bit                         |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| [HL].bit                        |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| СҮ                              | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 |      |                   | SET1<br>CLR1<br>NOT1 |

## (4) Call/instructions/branch instructions

CALL, CALLF, CALLT, BR, BC, BNC, BZ, BNZ, BT, BF, BTCLR, DBNZ

| Second Operand<br>First Operand | AX | !addr16    | !addr11 | [addr5] | \$addr16                     |
|---------------------------------|----|------------|---------|---------|------------------------------|
| Basic instruction               | BR | CALL<br>BR | CALLF   | CALLT   | BR<br>BC<br>BNC<br>BZ<br>BNZ |
| Compound instruction            |    |            |         |         | BT<br>BF<br>BTCLR<br>DBNZ    |

## (5) Other instructions

ADJBA, ADJBS, BRK, RET, RETI, RETB, SEL, NOP, EI, DI, HALT, STOP

[MEMO]

## APPENDIX A DEVELOPMENT TOOLS

The following development tools are available for the development of systems which employ the  $\mu$ PD78083 subseries.

Figure A-1 shows the configuration of the development tools.





| RA78K/0                 | This assembler converts a program written in mnemonics into an object code executable with a       |  |
|-------------------------|----------------------------------------------------------------------------------------------------|--|
| Assembler Package       | microprocontroller.                                                                                |  |
|                         | Further, this assembler is provided with functions capable of automatically creating symbol tables |  |
|                         | and branch instruction optimization.                                                               |  |
|                         | Used in combination with optional device file (DF78083).                                           |  |
|                         | Part Number: µSxxxxRA78K/0                                                                         |  |
| CC78K/0                 | This compiler converts a program written in C Language into an object code executable with an      |  |
| C Compiler Package      | microcontroller.                                                                                   |  |
|                         | Used in combination with optional assembler package (RA78K/0) and device file (DF78083).           |  |
|                         | Part Number: µSxxxxCC78K/0                                                                         |  |
| DF78083 <sup>Note</sup> | This is a file containing information inherent to the device.                                      |  |
| Device File             | Used in combination with optional RA78K/0, CC78K/0, SM78K0, ID78K0, or SD78K/0.                    |  |
|                         | Part Number: µS××××DF78083                                                                         |  |
| CC78K/0-L               | This is a function source program configurating object library included in CC78K/0 C compiler.     |  |
| C Library Source File   | Necessary for changing object library included in CC78K/0 in according to customer's               |  |
|                         | specifications.                                                                                    |  |
|                         | Part Number: µSxxxxCC78K0-L                                                                        |  |

## A.1 Language Processing Software

Note The DF78083 can be used commonly with all the RA78K/0, CC78K/0, SM78K0, ID78K0, and SD78K/0.

**Remark** ×××× of the part number differs depending on the host machine and OS used. Refer to the table below.

| <br>×××× | Host Machine           | OS                                  | Medium                   |
|----------|------------------------|-------------------------------------|--------------------------|
| 5A13     | PC-9800 Series         | MS-DOS                              | 3.5-inch 2HD             |
| 5A10     |                        | (Ver. 3.30 to 6.2 <sup>Note</sup> ) | 5-inch 2HD               |
| 7B13     | IBM PC/AT and their    | Refer to A.4                        | 3.5-inch 2HC             |
| 7B10     | compatible machines    |                                     | 5-inch 2HC               |
| 3H15     | HP9000 series 300™     | HP-UX™ (rel. 7.05B)                 | Cartridge tape (QIC-24)  |
| 3P16     | HP9000 series 700™     | HP-UX (rel. 9.01)                   | Digital audio tape (DAT) |
| 3K15     | SPARCstation™          | SunOS™ (rel. 4.1.1)                 | Cartridge tape (QIC-24)  |
| 3M15     | EWS-4800 series (RISC) | EWS-UX/V (rel. 4.0)                 |                          |

## A.2 PROM Programming Tools

## A.2.1 Hardware

| PG-1500         | This is a PROM programmer capable of programming the single-chip microcontroller with on-chip   |  |
|-----------------|-------------------------------------------------------------------------------------------------|--|
| PROM programmer | PROM by manipulating from the stand-alone or host machine through connection of the             |  |
|                 | separately available programmer adapter and the attached board. It can also program separate    |  |
|                 | PROM ICs with a capacity from 256 Kbits to 4 Mbits.                                             |  |
| PA-78P083CU     | This is a PROM programmer adapter for the $\mu$ PD78P083, and is used connected to the PG-1500. |  |
| PA-78P083GB     | PA-78P083CU: 42-pin plastic shrink DIP (600 mil)                                                |  |
| PROM programmer | 42-pin ceramic shrink DIP (with window) (600 mil)                                               |  |
| adapter         | PA-78P083GB: 44-pin plastic QFP (10 $\times$ 10 mm)                                             |  |

## A.2.2 Software

| PG-1500 controller | This program controls the PG-1500 from the host machine through serial and/or parallel interface |
|--------------------|--------------------------------------------------------------------------------------------------|
|                    | cable(s).                                                                                        |
|                    | Part Number: µS××××PG1500                                                                        |

**Remark** ×××× of the part number differs depending on the host machine and OS used. Refer to the table below.

## $\mu S \times \times \times PG1500$

| <br>×××× | Host Machine        | OS                                  | Medium       |
|----------|---------------------|-------------------------------------|--------------|
| 5A13     | PC-9800 Series      | MS-DOS                              | 3.5-inch 2HD |
| 5A10     |                     | (Ver. 3.30 to 6.2 <sup>Note</sup> ) | 5-inch 2HD   |
| 7B13     | IBM PC/AT and their | Refer to A.4                        | 3.5-inch 2HC |
| 7B10     | compatible machines |                                     | 5-inch 2HC   |

## A.3 Debugging Tools

## A.3.1 Hardware

| * | IE-78000-R-A           | This in-circuit emulator helps users in debugging hardware and software of an application system     |  |  |
|---|------------------------|------------------------------------------------------------------------------------------------------|--|--|
|   | In-circuit emulator    | that includes a 78K/0 series device. This in-circuit emulator supports integrated debugger           |  |  |
|   | (supporting integrated | (ID78K0). It is used with emulation probe and interface adapter that connects host machine.          |  |  |
|   | debugger)              |                                                                                                      |  |  |
| * | IE-70000-98-IF-B       | This is an adapter necessary when using the PC-9800 series (except notebook type) as a host          |  |  |
|   | Interface adapter      | machine for the IE-78000-R-A.                                                                        |  |  |
| * | IE-70000-98N-IF        | This is an adapter and cable necessary when using notebook type PC-9800 series as a host             |  |  |
|   | Interface adapter      | machine for the IE-78000-R-A.                                                                        |  |  |
| * | IE-70000-PC-IF-B       | This is an adapter necessary when using IBM PC/AT as a host machine for the IE-78000-R-A.            |  |  |
|   | Interface adapter      |                                                                                                      |  |  |
| * | IE-78000-R-SV3         | This is an adapter and cable necessary when using EWS as a host machine for the IE-78000-R-          |  |  |
|   | Interface adapter      | Α.                                                                                                   |  |  |
|   |                        | As Ethernet <sup>™</sup> , 10Base-5 is supported. With other mode, commercially available conversion |  |  |
|   |                        | adapter is necessary.                                                                                |  |  |
|   | IE-78000-R             | This is in-circuit emulator that debugs hardware and software when application system using          |  |  |
|   | In-circuit emulator    | 78K/0 series is developed. It supports screen debugger (SD78K/0), and is used with emulation         |  |  |
|   | (supporting screen     | probe. This emulator is connected to host machine or PROM programmer for efficient                   |  |  |
|   | debugger)              | debugging.                                                                                           |  |  |
|   | IE-78078-R-EM          | This board is used to emulate device-specific peripheral hardware (3.0 to 5.5 V), and is used with   |  |  |
|   | Emulation board        | in-circuit emulator.                                                                                 |  |  |
|   | IEP-78083CU-R          | This is a probe to connect an in-circuit emulator to target sytem.                                   |  |  |
|   | Emulation probe        | This probe is designed for 42-pin plastic shrink DIP (CU type) and 42-pin ceramic shrink DIP         |  |  |
|   |                        | (DU type).                                                                                           |  |  |
|   | EP-78083GB-R           | This is a probe to connect an in-circuit emulator to target system.                                  |  |  |
|   | Emulation probe        | This probe is designed for 44-pin plastic QFP (GB-3B4, GB-3BS-MTX types).                            |  |  |
|   |                        | This probe set includes a 44-pin conversion socket EV-9200G-44 for easier development of             |  |  |
|   |                        | target systems                                                                                       |  |  |
|   | EV-9200G-44            | This adapter connects the EP-78083GB-R to the target system board designed for 44-pin plastic        |  |  |
|   | Conversion socket      | QFP (GB-3B4, GB-3BS-MTX types).                                                                      |  |  |
|   | · · · · ·              |                                                                                                      |  |  |

**Remark** EV-9200G-44s are sold in sets of five units.

## A.3.2 Software (1/3)

| SM78K0           | This simulator can debug target system at C source level or assembler level while simulating   |  |
|------------------|------------------------------------------------------------------------------------------------|--|
| System simulator | operation of target system on host machine.                                                    |  |
|                  | SM78K0 runs on Windows.                                                                        |  |
|                  | By using SM78K0, logic and performance of application can be verified without in-circuit emula |  |
|                  | independently of hardware development, so that development efficiency and software quality can |  |
|                  | be improved.                                                                                   |  |
|                  | This simulator is used with optional device file (DF78083).                                    |  |
|                  | Part Number: µS××××SM78K0                                                                      |  |

**Remark** ×××× of the part number differs depending on the host machine and OS used. Refer to the table below.

#### μS<u>××××</u>SM78K0

| ×××× | Host Machine          | OS                                  | Medium       |
|------|-----------------------|-------------------------------------|--------------|
| AA13 | PC-9800 Series        | MS-DOS                              | 3.5-inch 2HD |
|      |                       | (Ver. 3.30 to 6.2 <sup>Note</sup> ) |              |
|      |                       | +                                   |              |
|      |                       | Windows (Ver. 3.0 to 3.1)           |              |
| AB13 | IBM PC/AT and their   | Refer to A.4                        | 3.5-inch 2HC |
|      | compatible machines   |                                     |              |
|      | (Windows in Japanese) |                                     |              |
| BB13 | IBM PC/AT and their   |                                     |              |
|      | compatible machines   |                                     |              |
|      | (Windows in English)  |                                     |              |

**Note** The task swap function is not available with this software through the function is provided in MS-DOS version 5.0 or later.

\*

## A.3.2 Software (2/3)

\*

| ID78K0              | This is control program that debugs 78K/0 series.                                                                                                                                                                                                                                                                                  |  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Integrated debugger | This program employs Windows on personal computer and OSF/Motif™ on EWS as graphical                                                                                                                                                                                                                                               |  |
|                     | user interface, and provides appearance and operability conforming to interface. In addition                                                                                                                                                                                                                                       |  |
|                     | debugging functions supporting C language are reinforced. Trace result can be displayed at C level by using window integration function that associates source program, disassemble display and memory display with trace result. Moreover, debugging efficiency of program using real-times and memory display with trace result. |  |
|                     |                                                                                                                                                                                                                                                                                                                                    |  |
|                     |                                                                                                                                                                                                                                                                                                                                    |  |
|                     | OS can be enhanced by using function expansion modules such as task debugger and system                                                                                                                                                                                                                                            |  |
|                     | performance analyzer.                                                                                                                                                                                                                                                                                                              |  |
|                     | This program is used in combination with optional device file (DF78083).                                                                                                                                                                                                                                                           |  |
|                     | Part Number: µSxxxxID78K0                                                                                                                                                                                                                                                                                                          |  |

**Remark** ×××× of the part number differs depending on the host machine and OS used. Refer to the table below.

## μS<u>××××</u>ID78K0

| ×××× | Host Machine          | OS                                  | Medium                   |
|------|-----------------------|-------------------------------------|--------------------------|
| AA13 | PC-9800 Series        | MS-DOS                              | 3.5-inch 2HD             |
|      |                       | (Ver. 3.30 to 6.2 <sup>Note</sup> ) |                          |
|      |                       | +                                   |                          |
|      |                       | Windows (Ver. 3.1)                  |                          |
| AB13 | IBM PC/AT and their   | Refer to A.4                        | 3.5-inch 2HC             |
|      | compatible machines   |                                     |                          |
|      | (Windows in Japanese) |                                     |                          |
| BB13 | IBM PC/AT and their   |                                     |                          |
|      | compatible machines   |                                     |                          |
|      | (Windows in English)  |                                     |                          |
| 3P16 | HP9000 series 700     | HP-UX (rel. 9.01)                   | Digital audio tape (DAT) |
| 3K15 | SPARCstation          | SunOS (rel. 4.1.1)                  | Cartridge tape (QIC-24)  |
| 3K13 |                       |                                     | 3.5-inch 2HC             |
| 3R16 | NEWS™ (RISC)          | NEWS-OS™ (6.1x)                     | 1/4-inch CGMT            |
| 3R13 |                       |                                     | 3.5-inch 2HC             |
| 3M15 | EWS4800 series (RISC) | EWS-UX/V (rel. 4.0)                 | Cartridge tape (QIC-24)  |

## A.3.2 Software (3/3)

| SD78K/0                 | This program controls IE-78000-R on host machine with IE-78000-R and host machine |  |
|-------------------------|-----------------------------------------------------------------------------------|--|
| Screen debugger         | connected with serial interface (RS-232-C).                                       |  |
|                         | It is used with optional device file (DF78083).                                   |  |
|                         | Part Number: µS××××SD78K0                                                         |  |
| DF78083 <sup>Note</sup> | B3 <sup>Note</sup> File containing device-specific information.                   |  |
| Device file             | It is used with optional RA78K/0, CC78K/0, SM78K0, ID78K0, or SD78K/0.            |  |
|                         | Part Number: µS××××DF78083                                                        |  |

Note This device file can be used for any of the RA78K/0, CC78K/0, SM78K0, ID78K0, SD78K/0 devices.

**Remark** ×××× of the part number differs depending on the host machine and OS used. Refer to the table below.

## $\mu$ S××××SD78K0

## $\mu S \times \times \times DF78083$

| _ | ×××× | Host Machine                                 | OS                                  | Medium       |
|---|------|----------------------------------------------|-------------------------------------|--------------|
|   | 5A13 | PC-9800 Series                               | MS-DOS                              | 3.5-inch 2HD |
|   | 5A10 |                                              | (Ver. 3.30 to 6.2 <sup>Note</sup> ) | 5-inch 2HD   |
|   | 7B13 | IBM PC/AT and their                          | Refer to A.4                        | 3.5-inch 2HC |
|   | 7B10 | compatible machines<br>(Windows in Japanese) |                                     | 5-inch 2HC   |

## ★ A.4 OS for IBM PC

As the OS for IBM PC, the following is supported.

To run SM78K0, ID78K0, or FE9200 (refer to **B.2 Fuzzy Inference Development Support System**), Windows (Ver. 3.0 to Ver. 3.1) is necessary.

| OS       | Version                                          |
|----------|--------------------------------------------------|
| PC DOS   | Ver. 5.02 to 6.3                                 |
|          | J6.1/V <sup>Note</sup> to J6.3/V <sup>Note</sup> |
| IBM DOS™ | J5.02/V <sup>Note</sup>                          |
| MS-DOS   | Ver. 5.0 to 6.22                                 |
|          | 5.0/V <sup>Note</sup> to 6.2/V <sup>Note</sup>   |

## A.5 System-Upgrade Method from Other In-Circuit Emulators to 78K/0 Series In-Circuit Emulator

If you already have an in-circuit emulator for the 78K series or the 75X/XL series, you can use that in-circuit emulator as the equivalent of the 78K/0 series in-circuit emulator IE-78000-R or IE-78000-R-A by replacing the internal break board with the IE-78000-R-BK.

| Series Name    | In-Circuit Emulator Owned                  | Board to be Purchased |
|----------------|--------------------------------------------|-----------------------|
| 75X/XL series  | IE-75000-R <sup>Note</sup> , IE-75001-R    | IE-78000-R-BK         |
| 78K/I series   | IE-78130-R, IE-78140-R                     |                       |
| 78K/II series  | IE-78230-R <sup>Note</sup> , IE-78230-R-A, |                       |
|                | IE-78240-R <sup>Note</sup> , IE-78240-R-A  |                       |
| 78K/III seires | IE-78320-R <sup>Note</sup> , IE-78327-R,   |                       |
|                | IE-78330-R, IE-78350-R                     |                       |

| Note | Maintenance | product |
|------|-------------|---------|
|      |             |         |

#### Table A-2. System-Up Method from Other In-Circuit Emulator to IE-78000-R-A

| Series Name    | In-Circuit Emulator Owned                    | Board to be Purchased           |
|----------------|----------------------------------------------|---------------------------------|
| 75X/XL series  | IE-75000-R <sup>Note 1</sup> , IE-75001-R    | IE-78000-R-BK <sup>Note 2</sup> |
| 78K/I series   | IE-78130-R, IE-78140-R                       |                                 |
| 78K/II series  | IE-78230-R <sup>Note 1</sup> , IE-78230-R-A, |                                 |
|                | IE-78240-R <sup>Note 1</sup> , IE-78240-R-A  |                                 |
| 78K/III seires | IE-78320-R <sup>Note 1</sup> , IE-78327-R,   |                                 |
|                | IE-78330-R, IE-78350-R                       |                                 |
| 78K/0 series   | IE-78000-R                                   | Note 2                          |

**Notes 1.** Maintenance product

2. Partial remodeling of the frame of the in-circuit emulator and replacement of the control/ trace board with a supervisor board must be done by NEC.

240

## Drawing and Footprint for Conversion Socket (EV-9200G-44)

Figure A-2. EV-9200G-44 Drawing (For Reference Only)

# Based on EV-9200G-44

(1) Package drawing (in mm)



|      |             | EV-9200G-44-G0E           |
|------|-------------|---------------------------|
| ITEM | MILLIMETERS | INCHES                    |
| A    | 15.0        | 0.591                     |
| В    | 10.3        | 0.406                     |
| С    | 10.3        | 0.406                     |
| D    | 15.0        | 0.591                     |
| E    | 4-C 3.0     | 4-C 0.118                 |
| F    | 0.8         | 0.031                     |
| G    | 5.0         | 0.197                     |
| н    | 12.0        | 0.472                     |
| I    | 14.7        | 0.579                     |
| J    | 5.0         | 0.197                     |
| К    | 12.0        | 0.472                     |
| L    | 14.7        | 0.579                     |
| М    | 8.0         | 0.315                     |
| N    | 7.8         | 0.307                     |
| 0    | 2.0         | 0.079                     |
| Р    | 1.35        | 0.053                     |
| Q    | 0.35±0.1    | $0.014^{+0.004}_{-0.005}$ |
| R    | ø1.5        | ø0.059                    |

## Figure A-3. EV-9200G-44 Footprint (For Reference Only)

## Based on EV-9200G-44 (2) Pad drawing (in mm)



|      |                      | EV-9200G-44-P1E                                                    |
|------|----------------------|--------------------------------------------------------------------|
| ITEM | MILLIMETERS          | INCHES                                                             |
| Α    | 15.7                 | 0.618                                                              |
| В    | 11.0                 | 0.433                                                              |
| С    | 0.8±0.02×10=8.0±0.05 | $0.031^{+0.002}_{-0.001} \times 0.394 {=} 0.315^{+0.002}_{-0.002}$ |
| D    | 0.8±0.02×10=8.0±0.05 | $0.031^{+0.002}_{-0.001} \times 0.394 {=} 0.315^{+0.002}_{-0.002}$ |
| E    | 11.0                 | 0.433                                                              |
| F    | 15.7                 | 0.618                                                              |
| G    | 5.00±0.08            | $0.197\substack{+0.003\\-0.004}$                                   |
| Н    | 5.00±0.08            | 0.197 <sup>+0.003</sup><br>-0.004                                  |
| I    | 0.5±0.02             | $0.02^{+0.001}_{-0.002}$                                           |
| J    | Ø1.57±0.03           | Ø0.062 <sup>+0.001</sup><br>-0.002                                 |
| К    | Ø2.2±0.1             | Ø0.087 <sup>+0.004</sup><br>-0.005                                 |
| L    | Ø1.57±0.03           | Ø0.062 <sup>+0.001</sup><br>-0.002                                 |

Caution Dimensions of mount pad for EV-9200 and that for target device (QFP) may be different in some parts. For the recommended mount pad dimensions for QFP, refer to "SEMICONDUCTOR DEVICE MOUNTING TECHNOLOGY MANUAL" (C10535E).

## APPENDIX B EMBEDDED SOFTWARE

This section describes the embedded software which are provided for the  $\mu$ PD78083 subseries to allow users to develop and maintain the application program for these subseries.

## ★ B.1 Real-time OS

| MX78K0 | $\mu$ ITRON-specification subset OS. Nucleus of MX78K0 is supplied.                           |
|--------|-----------------------------------------------------------------------------------------------|
| OS     | This OS performs task management, event management, and time management. It controls the task |
|        | execution sequence for task management and selects the task to be executed next.              |
|        | Part Number: μSxxxxMX78K0-ΔΔΔ                                                                 |

**Remark**XXXX and  $\Delta\Delta\Delta$  of the part number differs depending on the host machine and operating system used.Refer to the table below.

## $\mu S \times \times \times MX78K0-\Delta \Delta \Delta$

| ΔΔΔ | Product outline        | Note                                       |
|-----|------------------------|--------------------------------------------|
| 001 | Evaluation object      | Use for experimental production.           |
| xx  | Mass-production object | Use for mass production.                   |
| S01 | Source program         | Can be purchased only when object for mass |
|     |                        | production has been purchased.             |

| - ×××× | Host Machine          | OS                                  | Medium                   |
|--------|-----------------------|-------------------------------------|--------------------------|
| 5A13   | PC-9800 Series        | MS-DOS                              | 3.5-inch 2HD             |
| 5A10   |                       | (Ver. 3.30 to 6.2 <sup>Note</sup> ) | 5-inch 2HD               |
| 7B13   | IBM PC/AT and their   | Refer to A.4                        | 3.5-inch 2HC             |
| 7B10   | compatible machines   |                                     | 5-inch 2HC               |
| 3H15   | HP9000 series 300     | HP-UX (rel. 7.05B)                  | Cartridge tape (QIC-24)  |
| 3P16   | HP9000 series 700     | HP-UX (rel. 9.01)                   | Digital audio tape (DAT) |
| 3K15   | SPARCstation          | SunOS (rel. 4.1.1)                  | Cartridge tape (QIC-24)  |
| 3M1    | EWS4800 series (RISC) | EWS-UX/V (rel. 4.0)                 |                          |

| FE9000/FE9200          | This program supports input of fuzzy knowledge data (fuzzy rule and membership function),       |  |
|------------------------|-------------------------------------------------------------------------------------------------|--|
| Fuzzy Knowledge Data   | editing (edit), and evaluation (simulation)                                                     |  |
| Creation Tool          | FE9200 operations on Windows.                                                                   |  |
|                        | Part Number: µSxxxxFE9000 (PC-9800 series)                                                      |  |
|                        | $\mu$ SxxxxFE9200 (IBM PC/AT and their compatible machines)                                     |  |
| FT9080/FT9085          | This program converts fuzzy knowledge data obtained by using fuzzy knowledge data preparation   |  |
| Translator             | tool to RA78K/0 assembler source program.                                                       |  |
|                        | Part Number: µSxxxxFT9080 (PC-9800 series)                                                      |  |
|                        | $\mu$ SxxxxFT9085 (IBM PC/AT and their compatible machines)                                     |  |
| FI78K0                 | This program executes fuzzy inference by linking fuzzy knowledge data converted by translator.  |  |
| Fuzzy Inference Module | Part Number: $\mu$ SxxxxFI78K0 (PC-9800 series, IBM PC/AT and their compatible machines)        |  |
| FD78K0                 | This software supports evaluating and adjusting fuzzy knowledge data at hardware level by using |  |
| Fuzzy Inference        | in-circuit emulator.                                                                            |  |
| Debugger               | Part Number: $\mu$ S××××FD78K0 (PC-9800 series, IBM PC/AT and their compatible machines)        |  |

## **B.2** Fuzzy Inference Development Support System

**Remark** ×××× of the part number differs depending on the host machine and operating system used. Refer to the table below.

 $\begin{array}{l} \mu \text{S} \times \times \times \text{FE9000} \\ \mu \text{S} \times \times \times \text{FT9080} \\ \mu \text{S} \times \times \times \text{F178K0} \\ \mu \text{S} \underline{\times \times \times} \text{FD78K0} \end{array}$ 

| <br>×××× | Host Machine   | OS                                   | Medium       |
|----------|----------------|--------------------------------------|--------------|
| 5A13     | PC-9800 Series | MS-DOS                               | 3.5-inch 2HD |
| 5A10     |                | (Ver. 3.30 to 6.2 <sup>Note2</sup> ) | 5-inch 2HD   |

**Note** The task swap function is not available with this software through the function is provided in MS-DOS version 5.0 or later.

 $\begin{array}{l} \mu \text{S} \times \times \times \text{FE9200} \\ \mu \text{S} \times \times \times \text{FT9085} \\ \mu \text{S} \times \times \times \text{F178K0} \\ \mu \text{S} \underline{\times \times \times} \text{FD78K0} \end{array}$ 

| <br>XXXX | Host Machine        | OS           | Medium       |
|----------|---------------------|--------------|--------------|
|          |                     |              |              |
| 7B13     | IBM PC/AT and their | Refer to A.4 | 3.5-inch 2HC |
| 7B10     | compatible machines |              | 5-inch 2HC   |

# [MEMO]

## APPENDIX C REGISTER INDEX

# C.1 Register Index

|                | mode control register (TMC5)                   |             |
|----------------|------------------------------------------------|-------------|
|                | register 5 (TM5)                               |             |
| 8-bit timer    | register 6 (TM6)                               |             |
| [ ] ]          |                                                |             |
| [A]<br>ADCR:   | A/D conversion result register                 | 121         |
| ADCK.<br>ADIS: | A/D converter input select register            |             |
| ADIS:          | A/D converter mode register                    |             |
| ADIM:<br>ASIM: | Asynchronous serial interface mode register    |             |
| ASIM.<br>ASIS: | Asynchronous serial interface status register  |             |
| A313.          | Asynchronous serial interface status register  |             |
| [B]            |                                                |             |
| BRGC:          | Baud rate generator control register           | 144 153 165 |
| DIGC.          |                                                |             |
| [C]            |                                                |             |
| CR50:          | Compare registers 50                           | 84          |
| CR60:          | Compare registers 60                           |             |
| CSIM2:         | Serial operating mode register 2               |             |
| 001112.        |                                                |             |
| [E]            |                                                |             |
|                | terrupt mode register (INTM0)                  | 179         |
|                | terrupt mode register (INTM1)                  |             |
|                |                                                |             |
| [I]            |                                                |             |
| IF0H:          | Interrupt request flag register 0H             |             |
| IF0L:          | Interrupt request flag register 0L             |             |
| IF1L:          | Interrupt request flag register 1L             |             |
| IMS:           | Memory size switching register                 |             |
| INTMO:         | External interrupt mode register 0             |             |
| INTM1:         | External interrupt mode register 1             |             |
| Interrupt m    | ask flag register 0H (MK0H)                    |             |
| -              | ask flag register 0L (MK0L)                    |             |
| -              | ask flag register 1L (MK1L)                    |             |
|                |                                                | - /         |
| [M]            |                                                |             |
| MK0H:          | Interrupt mask flag register 0H                |             |
| MK0L:          | Interrupt mask flag register 0L                |             |
| MK1L:          | Interrupt mask flag register 1L                |             |
|                | ze switching register (IMS)                    |             |
| -              |                                                |             |
| [O]            |                                                |             |
| OSMS:          | Oscillation mode selection register            |             |
| OSTS:          | Oscillation stabilization time select register |             |

| [P]       |                                     |  |
|-----------|-------------------------------------|--|
| P0:       | Port0                               |  |
| P1:       | Port1                               |  |
| P3:       | Port3                               |  |
| P5:       | Port5                               |  |
| P7:       | Port7                               |  |
| P10:      | Port10                              |  |
| PCC:      | Processor clock control register    |  |
| PM0:      | Port mode register 0                |  |
| PM1:      | Port mode register 1                |  |
| PM3:      | Port mode register 3                |  |
| PM5:      | Port mode register 5                |  |
| PM7:      | Port mode register 7                |  |
| PM10:     | Port mode register 10               |  |
| PR0H:     | Priority specify flag register 0H   |  |
| PR0L:     | Priority specify flag register 0L   |  |
| PR1L:     | Priority specify flag register 1L   |  |
| PSW:      | Program status word                 |  |
| PUOH:     | Pull-up resistor option register H  |  |
| PUOL:     | Pull-up resistor option register L  |  |
| [R]       |                                     |  |
| RXB:      | Receive buffer register             |  |
| [S]       |                                     |  |
| SAR:      | Successive approximation register   |  |
| SFR:      | Special-function register           |  |
| Serial op | erating mode register 2 (CSIM2)     |  |
| [T]       |                                     |  |
| TCL0:     | Timer clock select register 0       |  |
| TCL2:     | Timer clock select register 2       |  |
| TCL5:     | Timer clock select register 5       |  |
| TCL6:     | Timer clock select register 6       |  |
| TM5:      | 8-bit timer register 5              |  |
| TM6:      | 8-bit timer register 6              |  |
| TMC5:     | 8-bit timer mode control register 5 |  |
| TMC6:     | 8-bit timer mode control register 6 |  |
| TXS:      | Transmit shift register             |  |
| [W]       |                                     |  |
| WDTM:     | Watchdog timer mode register        |  |

## APPENDIX D REVISION HISTORY

Major revisions by edition and revised chapters are shown below.

| Edition | Major revisions from previous version                                                                                                                                                                                              | Revised Chapter                           |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| 2nd     | The following products have been already developed<br>μPD78081CU-xxx, 78081GB-xxx-3B4, 78082CU-xxx,<br>78082GB-xxx-3B4, 78P083CU, 78P083DU, 78P083GB-3B4                                                                           | Throughout                                |
|         | The following products have been added<br>μPD78081GB-xxx-3BS-MTX, 78082GB-xxx-3B4-MTX,<br>780P083GB-3BS-MTX, 78081GB(A)-xxx-3B4,78082GB(A)-xxx-3B4,<br>78P083CU(A), 78P083GB(A)-3B4, 78P083GB(A)-3BS-MTX,<br>78081GB(A2)-xxx-3B4   |                                           |
|         | Power voltage changed to $V_{DD} = 1.8$ to 5.5V.                                                                                                                                                                                   |                                           |
|         | 1.6 78K/0 Series Development has been changed.                                                                                                                                                                                     | CHAPTER 1 OUTLINE                         |
|         | 1.9 Differences between the μPD78081, 78082, and 78P083,<br>the μPD78081(A), 78082(A), and 78P083(A), and<br>the μPD78081(A2) has been added.                                                                                      |                                           |
|         | Cautions regarding the use of functions in common with <b>2.2.5</b> (2) (d) ASCK has been added.                                                                                                                                   | CHAPTER 2 PIN FUNCTION                    |
|         | Cautions concerning the Write to OSMS Command has been added to <b>5.3 (2) Oscillation mode select register (OSMS).</b>                                                                                                            | CHAPTER 5 CLOCK GENERATOR                 |
|         | Cautions concerning external clock input in <b>5.4.1 Main system clock oscillation</b> has been changed.                                                                                                                           |                                           |
|         | Figure 7-3. Watchdog Timer Mode Register Format, notes and cautions have been added.                                                                                                                                               | CHAPTER 7 WATCHDOG TIMER                  |
|         | Description of 7.4.2 Interval timer operation has been changed.                                                                                                                                                                    |                                           |
|         | Cautions with regard to rewriting TCL0 to other than same data has been added to 8.3 (1) Timer clock select register 0 (TCL0).                                                                                                     | CHAPTER 8 CLOCK OUTPUT CONTROL<br>CIRCUIT |
|         | The HSC bit has been added to the A/D Converter Mode Register in Figure10-1. A/D Converter Block Diagram.                                                                                                                          | CHAPTER 10 A/D CONVERTER                  |
|         | 10.3 (1) A/D converter mode register (ADM), 13.1.1 Standby function, and Cautions have been added.                                                                                                                                 |                                           |
|         | Figure 11-1. Serial Interface Channel 2 Block Diagram has been corrected.                                                                                                                                                          | CHAPTER 11 SERIAL INTERFACE<br>CHANNEL 2  |
|         | <b>11.3 (4) (a), 11.4.2 (1) (d) (i) Generation of baud rate transmit/</b><br><b>receive clock by means of main system clock</b> have been added.<br>76800 bps has been added to baud rate generated from the main<br>system clock. |                                           |
|         | Figure 11-10. Receive Error Timing has been corrected.                                                                                                                                                                             |                                           |
|         | 11.4.3 (c) Baud rate generator control register (BRGC) has been added.                                                                                                                                                             |                                           |
|         | <b>15.1 Memory Size Switching Register</b> has been changed from W to R/W.                                                                                                                                                         | CHAPTER 15 μPD78P083                      |
|         | Items and cautions have been added to Table 15-1. Differences between the $\mu$ PD78P083 and Mask ROM Versions.                                                                                                                    |                                           |
|         | A description of the QTOP icon has been added to 15.5 Screening of One-Time PROM Versions.                                                                                                                                         |                                           |

| Edition | Major revisions from previous version                        | Revised Chapter              |  |
|---------|--------------------------------------------------------------|------------------------------|--|
| 2nd     | Figure A-1. Development Tool Configuration has been changed. | APPENDIX A DEVELOPMENT TOOLS |  |
|         | APPENDIX A DEVELOPMENT TOOLS                                 |                              |  |
|         | The following Development Tools have been added:             |                              |  |
|         | IE-78000-R-A, IE-70000-98-IF-B, IE-70000-98-N-IF,            |                              |  |
|         | IE-70000-PC-IF-B, IE-78000-R-SV3, SM78K0, ID78K0             |                              |  |
|         | A.4 OS for IBM PC has been added.                            |                              |  |
|         | Table A-2. System-Up Method from Other In-Circuit Emulator   |                              |  |
|         | to IE-78000-R-A has been added.                              |                              |  |
|         | B.1 Real-time OS has been added.                             | APPENDIX B EMBEDDED SOFTWARE |  |



# **Facsimile** Message

| From:   |      |  |  |
|---------|------|--|--|
| Name    | <br> |  |  |
| Company |      |  |  |

FAX

Although NEC has taken all possible steps to ensure that the documentation supplied to our customers is complete, bug free and up-to-date, we readily accept that errors may occur. Despite all the care and precautions we've taken, you may encounter problems in the documentation. Please complete this form whenever you'd like to report errors or suggest improvements to us.

Address

Tel.

Thank you for your kind support.

| North America<br>NEC Electronics Inc.<br>Corporate Communications Dept.<br>Fax: 1-800-729-9288<br>1-408-588-6130 | Hong Kong, Philippines, Oceania<br>NEC Electronics Hong Kong Ltd.<br>Fax: +852-2886-9022/9044 | Asian Nations except Philippines<br>NEC Electronics Singapore Pte. Ltd.<br>Fax: +65-250-3583                                        |
|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| <b>Europe</b><br>NEC Electronics (Europe) GmbH<br>Technical Documentation Dept.<br>Fax: +49-211-6503-274         | Korea<br>NEC Electronics Hong Kong Ltd.<br>Seoul Branch<br>Fax: 02-528-4411                   | Japan<br>NEC Corporation<br>Semiconductor Solution Engineering Division<br>Technical Information Support Dept.<br>Fax: 044-548-7900 |
| South America<br>NEC do Brasil S.A.<br>Fax: +55-11-889-1689                                                      | <b>Taiwan</b><br>NEC Electronics Taiwan Ltd.<br>Fax: 02-719-5951                              |                                                                                                                                     |

I would like to report the following error/make the following suggestion:

Document title:

Document number: \_\_\_\_\_ Page number: \_\_\_\_\_

If possible, please fax the referenced page or drawing.

| <b>Document Rating</b> | Excellent | Good | Acceptable | Poor |
|------------------------|-----------|------|------------|------|
| Clarity                |           |      |            |      |
| Technical Accuracy     |           |      |            |      |
| Organization           |           |      |            |      |